VAX 11/780 

DATA PATH DESCRIPTION 
AA-H307B-TE 



February 1979 



Digital Euipment Corporation - Maynard, Ma 



Page 2 



First Printing, February 1979 

The information in this document is subject to change without notice 
and should not be construed as a commitment by Digital Equipment 
Corporation. Digital Equipment Corporation assumes no responsibility 
for any errors that may appear in this document. 

The software described in this document is furnished under a license 
and may be used or copied only in accordance with the terms of such 
license. 

No responsibility is assumed for the use or reliability of software or 
equipment that is not supplied by DIGITAL or its affiliated companies. 

Copyright (C) 1979 by Digital Equipment Corporation 

The postage prepaid READER'S COMMENTS form on the last page of this 
document requests the user's critical evaluation to assist us in 
preparing future documentation. 

The following are trademarks of Digital Equipment Corporation: 

DIGITAL DECsystem-10 MASSBUS 

DEC DECtape OMNIBUS 

PDP DIBOL OS/8 

DECUS EDUSYSTEM PHA 

UNIBUS FLIP CHIP RSTS 

COMPUTER LABS FOCAL RSX 

COMTEX INDAC TYPESET- 8 

DDT LAB -8 TYPE SET- 10 

DECCOMM DECsystem-20 TYPESET-11 

ASSIST-11 RTS-8 ITPS-10 
TMS-11 



Page 3 



CHAPTER 1 



DATA PATH SPECIFICATION 



1.1 ARITHMETIC SECTION 1-3 

1.1.1 ALU 1-3 

1.1.2 AMX 1-5 

1.1.3 BMX 1-7 

1.1.4 SHF 1-11 

1.1.5 KMX 1-14 

1.1.6 MASK 1-18 

1.1.7 LC and RC 1-18 

1.1.8 LA and LB 1-19 

1.1.9 RLOG and PCSV 1-25 

1.2 EXPONENT SECTION 1-26 

1.2.1 EALU 1-26 

1.2.2 EAMX 1-27 

1.2.3 EBMX 1-28 

1.2.4 FE 1-29 

1.2.5 STATE 1-30 

1.2.6 SMX 1-31 

1.2.7 SC 1-32 

1.3 DATA SECTION 1-33 

1.3.1 DFMX 1-33 

1.3.1.1 BUS DFMX 1-34 

1.3.2 QMX 1-35 

1.3.3 DMX 1-36 

1.3.4 DAL 1-37 

1.3.5 Q 1-38 

1.3.6 D 1-41 

1.3.6.1 MDBAL 1-44 

1.3.7 D PGEN 1-46 

1.3.8 BAL 1-46 

1.3.9 RAMX 1-50 

1.3.9.1 RBMX 1-50 

1.4 ADDRESS SECTION 1-51 

1.4.1 VIBA 1-51 

1.4.2 VA 1-52 

1.4.3 VAMUX 1-53 

1.4.4 PC 1-54 

1.4.5 PCADD 1-55 

1.4.6 PCMX 1-56 



CHAPTER 2 



2.1 
2.2 
2.3 
2.4 
2.5 
2.6 
2.7 
2.8 
2.9 



MICRO SEQUENCER SPECIFICATION 

NORMAL MODE 2-1 

MICRO ECO CONTROL (UECO) MODE 2-1 

MICRO TRAP (UTRAP) MODE 2-3 

CONTROL STORE PARITY ERROR MICRO TRAP MODE . . 2-4 

CACHE STALLS 2-6 

SYSTEM INITIALIZE 2-7 

MICRO SUBROUTINE FIELD (USUB) 2-8 

JUMP FIELD (JFIELD OR UJMP) 2-8 

BRANCH ENABLE FIELD (UBEN) 2-8 



Page 4 



2.10 OTHER FIELDS - UBS+UBCT (NOT ON USC) 2-9 

2.11 CALL SUBROUTINE 2-9 

2.12 RETURN SUBROUTINE 2-9 

2.13 POWER UP OR DOWN 2-10 

2.14 CONSOLE CONTROLLED OPERATIONS 2-11 

2.15 PICO SEQUENCER AND PRIORITY DECODING 2-13 

2.16 UPC ADDRESS LATCHING 2-14 



CHAPTER 3 INTERNAL DATA BUS SPECIFICATION 

3.1 FUNCTIONAL OPERATION 3-1 

3.1.1 Normal Operation 3-1 

3.1.1.1 ID BUS Addresses 3-2 

3.1.1.2 ID BUS Directional Control 3-3 

3.1.1.3 ID BUS Data 3-3 

3.1.1.4 Signal Summary 3-3 

3.1.1.5 ID BUS Control 3-3 

3.1.2 Maintenance Operation 3-4 

3.1.2.1 Console Control of ID BUS 3-5 

3.2 ID BUS REGISTER DESCRIPTION 3-5 

3.2.1 IBUF DATA 3-5 

3.2.2 SYSTEM ID 3-5 

3.2.3 CNSL RXCS 3-5 

3.2.4 CNSL RXDB 3-6 

3.2.5 CNSL TXCS 3-6 

3.2.6 CNSL TXDB 3-6 

3.2.7 CLOCK CONTROL/STATUS 3-6 

3.2.8 NEXT INTERVAL COUNT 3-7 

3.2.9 INTERVAL COUNT 3-7 

3.2.10 TIME OF DAY 3-7 

3.2.11 ACC REG THRU 1 3-8 

3.2.12 ACC MAINT 3-8 

3.2.13 ACC CONTROL/STATUS 3-8 

3.2.14 TBUF DATA 3-8 

3.2.15 TBUF REGO 3-9 

3.2.16 TBUF REG1 3-9 

3.2.17 SBI SILO . . 3-9 

3.2.18 SBI TIMEOUT ADDRESS 3-10 

3.2.19 SBI FAULT/STATUS 3-10 

3.2.20 SBI SILO COMPARATOR . . . 3-10 

3.2.21 SBI MAINTENANCE 3-11 

3.2.22 SBI CACHE PARITY 3-11 

3.2.23 USTACK 3-11 

3.2.24 UBREAK 3-12 

3.2.25 WCS ADDRESS 3-12 

3.2.26 WCS DATA/ STATUS 3-12 

3.2.27 D,Q (MAINT MODE ONLY) . 3-13 

3.2.28 SIR 3-13 

3.2.29 PSL . 3-13 

3.2.30 CPU ERROR/STATUS 3-14 

3.2.31 VECTOR 3-15 

3.2.32 FPDA, D.SV, Q.SV 3-16 

3.2.33 P0BR, P1BR, SBR, P0LR, PlLR r SLR, PCBB, 

SCBB KSP f ESP, SSP f USP, ISP 3-16 



Page 5 



CHAPTER 4 



INSTRUCTION BUFFER 



4.1 BUFFER DATA PATH 4-1 

4.1.1 Buffer Register 4-1 

4.2 SHIFT NETWORK 4-2 

4.2.1 Multiplexer Shift Network 4-2 

4.2.1.1 MICRO Control Use 4-3 

4.3 INPUT MULTIPLEXER 4-4 

4.4 BYTE ROTATOR 4-4 

4.5 I-STREAM DATA MUX 4-5 

4.6 PC UPDATES . 4-6 

4.7 IR DECODE 4-7 

4.7.1 Register Latched Number ..... 4-8 

4.7.1.1 Context Lookup 4-8 

4.7.1.1.1 Specifier 1 Constant 4-8 

4.7.1.1.2 Specifier 2 Constant 4-9 

4.7.1.2 Data Length Field 4-9 

4.8 EXECUTION POINTS 4-9 

4.9 FIRST PART DONE 4-10 

4.9.1 IB Addressing 4-10 

4.10 CACHE INTERFACE 4-11 

4.11 ACCELERATOR INTERFACE 4-11 



CHAPTER 5 



INTERRUPTS & EXCEPTIONS 



5.1 INTERRUPTS 5-1 

5.1.1 Interrupt Priority Level (IPL) . 5-1 

5.1.2 System Control Block 5-2 

5.1.3 Vectors 5-2 

5.1.4 Interrupt Requests and their Vectors .... 5-3 

5.1.5 Description of Interrupt Conditions 5-5 

5.1.5.1 CPU Power Fail 5-5 

5.1.5.2 CPU Timeout 5-5 

5.1.5.3 SBI Fault 5-5 

5.1.5.4 SBI Alert 5-6 

5.1.5.5 CRD/RDS 5-6 

5.1.5.6 SBI SILO Compare . 5-6 

5.1.5.7 Interval Timer 5-6 

5.1.5.8 External Device Interrupts 5-7 

5.1.5.9 Console Terminal Interrupts 5-7 

5.1.5.10 Software Interrupts 5-7 

5.1.6 UWORD Control for Interrupts 5-8 

5.1.6.1 Interrupt Strobe 5-8 

5.1.6.2 Interrupt Acknowledge 5-8 

5.1.7 Registers used for interrupt servicing . . . 5-9 

5.1.7.1 Interrupt priority level register - IPLR 5-9 

5.1.7.2 System control block base register - SCBB 5-9 

5.1.7.3 Vector register, VECTOR . 5-10 

5.1.7.4 Asynchronous system trap level reg . ASTR 5-11 

5.1.7.5 Software interrupt summary register SISR 5-11 

5.1.7.6 Software interrupt request register SIRR 5-12 



Page 6 

5.2 EXCEPTIONS 5-12 

5.2.1 Classes of exceptions 5-13 

5.2.1.1 Traps 5-13 

5.2.1.2 Faults 5-13 

5.2.1.3 Aborts 5-13 

5.2.2 Exception conditions and their vectors . . . 5-13 

5.2.3 Description of exception conditions 5-14 

5.2.3. Machine check - Raises IPL to IF .... 5-14 

5.2.3.1.1 Read timeout 5-14 

5.2.3.1.2 Read data substitute 5-15 

5.2.3.1.3 Translation buffer parity error . . '. 5-15 

5.2.3.1.4 Cache parity error . . 5-15 

5.2.3.1.5 Control store parity error 5-15 

5.2.3.1.6 Illegal Machine Sequence Error .... 5-15 

5.2.3.2 Kernel stack not valid - Raises IPL to IF 5-16 

5.2.3.3 Reserved DEC opcodes & priv. instr . . . 5-16 

5.2.3.4 Reserved cust opcodes 5-16 

5.2.3.5 Reserved operands 5-16 

5.2.3.5.1 Illegal floating number - Fault . . . 5-16 

5.2.3.5.2 Bit field too wide - Fault 5-16 

5.2.3.5.3 Illegal entry mask - Fault 5-17 

5.2.3.5.4 PSW MBZ FIELD not zero - Fault .... 5-17 

5.2.3.5.5 Illegal PCB entry - Abort 5-17 

5.2.3.5.6 Illegal PSL image - Fault 5-17 

5.2.3.5.7 Illegal processor reg - Fault .... 5-17 

5.2.3.5.8 Decimal string too long - Fault . . . 5-18 

5.2.3.5.9 Reserved pattern operator - Fault . . 5-18 

5.2.3.6 Reserved addressing modes - Fault .... 5-18 

5.2.3.7 Access control violation - Fault .... 5-18 

5.2.3.8 Translation not valid - Fault 5-19 

5.2.3.9 Trace trap - TRAP 5-20 

5.2.3.10 BPT opcode - FAULT 5-20 

5.2.3.11 Compatability mode trap - TRAP/ABORT . . 5-20 

5.2.3.12 Arithmetic trap - TRAP 5-21 

5.2.3.13 CHMX opcodes 5-22 

5.2.4 Acknowledging exceptions 5-23 

5.2.4.1 Error acknowledging 5-23 

5.2.4.2 Arithmetic trap acknowledging 5-23 

5.2.4.3 Trace trap acknowledging 5-23 

5.2.4.4 UWORD control for exceptions 5-24 

5.3 MACHINE HALTS 5-24 

5.3.1 Halt conditions 5-24 

5.3.1.1 Halt Instruction 5-24 

5.3.1.2 CNSL halt 5-24 

5.3.1.3 CHMX instructions 5-25 

5.3.1.4 Interrupt stack not valid 5-25 

5.3.1.5 Halt code from vector 5-25 

5.4 UTRAP FUNCTION 5-25 

5.4.1 UTRAP Condi tons And Their Vectors 5-25 



Page 7 



5.4.2 Description of utrap conditions . 5-26 

5.4.2.1 System Init 5-26 

5.4.2.2 Errors 5-26 

5.4.2.3 Reserved Floating Operand 5-26 

5.4.2.4 TBUF Miss 5-26 

5.4.2.5 Protection Violation 5-26 

5.4.2.6 MBIT 5-26 

5.4.2.7 Page Boundary • • 5-26 

5.4.2.8 Unaligned Data 5-26 

5.5 SERIALIZATION OF EVENTS AT FORK A 5-27 



CHAPTER 6 



6.1 
6.2 
6.3 
6.4 
6.5 
6.6 

6.7 
6.8 
6.9 



MACHINE CHECK ABORT/FAULT/HALT 

MACHINE CHECKS 6_1 

INSTRUCTION ABORTS 6_2 

INSTRUCTION FAULTS ..... 6-3 

INSTRUCTION HALTS 6-3 

ERROR LOGOUT 6 " 3 

INITIALIZATION OF CP, TBUF, CACHE, & 

SBI STATUS REGISTERS 6-6 

CPU/CONSOLE INTERFACE STATE 6-6 

HALT IDENTIFICATION CODES 6-7 

RETRYABLE INSTRUCTION LIST 6-8 



CHAPTER 7 



7.1 

7.2 

7.3 

7.4 

7.5 

7.6 

7.7 

7.8 

7.9 

7.10 

7.11 

7.12 

7.13 

7.14 

7.15 

7.16 

7.17 

7.18 

7.19 



CACHE-SBI-TB SUBSYSTEM 

MD BUS 7_1 

CS BUS 7_1 

V BUS Z~l 

CLOCK BUS 7-2 

ADDRESS BUS 7 ~ 2 

FROM IB 7 " 2 

TO IB 7 ~ 3 

FROM MICROSEQUENCE 7 " 3 

TO MICROSEQUENCER 7 " 3 

FROM TRAPS AND INTERRUPTS 7-4 

TO TRAPS AND INTERRUPTS 7 ~4 

FROM DATA PATH - NONE 7_6 

TO DATA PATH 7_6 

SELECTED INTERNAL SUBSYSTEM SIGNALS 7-6 

MICROBRANCHES 7 " 6 

MICROORDERS 7 ~ 7 

REGISTERS 7 ~^ 

GENERAL DESCRIPTION 7.-30 

MICROCODING SUGGESTIONS 7-31 



Page 8 



CHAPTER 8 



8.1 
8.2 
8.3 
8.4 
8.5 



VAX 11/780 CONSOLE SUBSYSTEM 

THE CONSOLE/CPU INTERFACE g-3 

ID BUS REGISTERS ON CIB .'!!.* 8-6 

THE Q-BUS REGISTERS (FIGURES 4 AND 5) ..." ' 8-8 

USE OF- THE Q-BUS REGISTERS .' 8-20 

TERMINAL CONTROL REGISTERS IN THE PROCREG SPACE 8-26 



CHAPTER 9 



9.1 

9.2 

9.3 

9.4 

9.4.1 

9.4.1.1 

9.4.2 

9.4.2.1 

9.4.2.2 

9.4.2.3 

9.4.3 

9.5 

9.5.1 

9.5.1.1 

9.5.2 

9.5.3 

9.5.3.1 

9.5.4 

9.6 



APPENDIX A 

A.l 
A. 2 



VAX 11/780 ACCELERATOR INTERFACE 

DEFINITIONS. # 9 _ 2 

INTERFACE SPECIFICATION !!.".'!.* 9-2 

GLOSSARY OF INTERFACE SIGNALS '.'.'. 9-2 

ACCELERATOR INTERFACE OPERATION '.'.'. 9-6 

Data transfer ' * g_g 

Initial data transfer '.*.'. 9-6 

Accelerator control . 9.7 

Accelerator trap [ " 9-7 

Alternate trap function ] 9-7 

CPU branches 9_7 

System clock . 

DATA INTERFACE !!!."!.* 9-8 

Data to accelerator . ! ! ! ! ! 9-8 

Data from accelerator [ * 9-8 

Alternate data transfers * 9-9 

Accelerator status registers ...!!!!! 9-9 

Accelerator maintenance register .... 9-9 

General register updates 9-9 

ISB INTERFACE ! ! ! ! 9-10 

CONTROL WORD 

THE CONTROL WORD A _-, 

ABORT CONDITION . . . !!!.!!.* A-5 



APPENDIX B 

B.l 
B.2 
B.3 
B.4 



WRITABLE CONTROL STORE 

WRITEABLE CONTROL STORE MEMORY ...... B-l 

WRITE DATA TO WCS # B _ x 

WCS ADDRESS REGISTER .....!!!!!!."! B-2 

EXTERNAL JUMPER SELECTIONS & RAM TYPE SELECTION B-2 



Page 9 



APPENDIX C 

C.l 
C.2 
C.3 
C.4 

C.5 



MICRO-CODE DEBUGGER INTERFACE 

OBJECTIVES c_1 

MICRO-CODE DEBUGGER ENTRY & EXIT C-l 

MICRO-CODE DEBUGGER/MICRO-MACHINE/STATE CONTROL C-2 
MICRO-CODE DEBUGGER INTERNAL REGISTER & 

MEMORY EXAMINE & DEPOSIT C-4 

LIST OF DEPENDENT MICRO-ORDERS C-5 



APPENDIX D 



WCS DEBUGGER HELP FILE 



APPENDIX E 

E.l 
E.2 
E.3 



PROM CONTROL STORE SPECIFICATION 

PROM ADDRESS PATH E-l 

PARITY ERROR DETECTION E-l 

EXTERNAL JUMPER SELECTIONS & CS TYPE SELECTION E-2 



CHAPTER 1 
DATA PATH SPECIFICATION 



The VAX 11/780 CPU DATA PATH consists of four sections for processing 
data and addresses as specified in the VAX and compatibility mode 
instruction sets. The EXPONENT, ADDRESS, ARITHMETIC, and DATA 
sections each operate as independent units which are capable of 
processing data or addresses in parallel with the operations taking 
place in the other sections. 

The block diagram for the VAX 11/780 CPU Data Path is given in Figure 
1-1. 
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1.1 ARITHMETIC SECTION 

The ARITHMETIC SECTION of the DATA PATH contains the GENERAL 
REGISTERS, a bit mask generator, a constant generator, shifter, 
temporary storage registers, and register inputs from the ADDRESS and 
DATA SECTIONS so that the necessary arithmetic and logical operations 
can be performed on data and addresses. 

Three data types are processed in the ARITHMETIC SECTION which consist 
of 8 bit bytes, 16 bit words, and 32 bit long words. 

The data type is controlled by the UDT control field which selects the 
desired sign or zero extension, index constants, index shifting, and 
GENERAL REGISTER storage control. 



1.1.1 ALU 

Arithmetic and Logic Unit 

The ALU provides the main processing power of the ARITHMETIC SECTION 
by performing 32 bit arithmetic with fast carry look ahead logic or 32 
bit logical operations. 

ALU data types: 

32 bit arithmetic or logical operation (.OP.). 



31 
+ — 



00 
+ 



A(31:00) .OP. B(31:00) 



ALU CONTROL 

The ALU operation is controlled by the UALU field of the UWORD which 
may define the function explicitly or allow the function to be 
controlled by the instruction decode logic. The command codes are 
grouped into two classes, arithmetic and logic modes. The arithmetic 
mode operation requires more processing time and puts restrictions on 
the source data used in the case of slow constants (section 1.3.5), 
register set contents (section 1.3.7), Temporary scratch pad contents 
(section 1.3.8), packed floating format (section 1.3.3) or the 
conditional BMX selection of PC in the state immediately following the 
loading of the first specifier (section 1.3.3). There are no similar 
restricitons on logic mode functions. 
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UALU 

Uword Arithmetic and Logic Unit control field, 4 bits. 



Uword hex code Function 

(D) A. MINUS. B 

1 A. MINUS. B (RLOG) 

2 A. MINUS. B. MINUS. 1 

3 INSTRUCTION DEP. 

4 A. PLUS. B. PLUS. 1 

5 A. PLUS. B 

6 A. PLUS. B. (RLOG) 

A.ORNOT.B 

7 A.OR.B 

8 A.XOR.B 

A.ANDNOT.B 

9 A.AND.B 
A .NOT. A 

B A. PLUS. B. PLUS. C 

C A . OR . B 

D A.AND.B 

E B 

F A 



(D) 



Mode 

A 

A 

A 

A&L 

A 

A 

A 

L 
L 

L 
L 
A 
L 
L 
L 
L 



When the UALU field = 3 the ALU functions are the result of the 
instruction being executed. Under Instruction Dependent mode the full 
32 logical and arithmetic functions of the ALU (74S181) are available. 
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(D) 

The C input to the ALU can be forced for either PSL C or NOT PSLC. 
This will provide the useful ALU functions of: 



A. PLUS. B. PLUS. C 

A. MINUS. B. MINUS. C 

A. PLUS. C 

A. MINUS. C 

A. PLUS. A. PLUS. C 



A. PLUS. B. PLUS. NOT. C 

A. MINUS. B. MINUS. NOT. C 

A. PLUS. NOT. C 

A. MINUS. NOT. C 

A . PLUS . A . PLUS . NOT . C 



independent of the ALU function selected, the AMX can be forced to 
zero giving: B+l etc. 

When UALU field = 1 or 6 the RLOG stack is updated with the general 
register (RA) address, the lower four bits of the KMX and a bit to 
determine if an add or subtract is requested. 



1.1.2 AMX 



alu A input Multiplexor 

The AMX provides the data source for the A input to the ALU. Sign or 
zero extension of the data type from either the D or Q register in the 
DATA SECTION is provided since the ALU operates on 32 bit data 
structures only. 



AMX data types: 



31 



LA 



00 



LA(31:00) 



31 



RAMX or SXT[L] 



00 



RAMX (31:00) 
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SXT[B] 

31 08 07 00 

^ ^ _______ __ _ 

I RAMX07 | RAMX (07:00) | 

I I I 

SXT [W] 

31 16 15 00 

______________ _ _ 

I RAMX 15 I RAMX (15:00) | 

____-_______„_______ ' ' 

0XT[B] 

31 08 07 00 

2 

! ' ' 

| o< >0 I RAMX (07:00) | 

I ^ _„_„„_„ '_ ' 

OXT [W] 

31 C 16 15 00 

_ _ 

| < >0 I RAMX (15:00) | 

L_._________.__. ' i 


31 00 

_ 

I < : >0 | 
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AMX CONTROL 

The data format of 
while the sign or 
The zero extension 



the RMX is selected by the UAMX field of the UWORD, 
zero extension position is chosen by the UDT field, 
of a long word data type is a special case and will 



force all zeroes at the output of AMX. 



UAMX 

Uword alu A input Multiplexor control field, 2 bits. 
LA 

1 RAMX 

2 RAMX SXT [UDT] (Sign eXTension) 

3 RAMX OXT [UDT] (• eXTension) 



UDT 



Uword Data Type select field, 2 bits. 



LONGWORD 

1 WORD 

2 BYTE 

3 INSTRUCTION 



SXT[L] or 
SXT[W] or 
SXT[B] or 
DEPENDENT 





0XT[W] 
0XT[B] 
: Any 



of above 



When UDT = 3 the instruction decode logic determines the data type to 
be used in the ARITHMETIC SECTION. This provides data type 
information for instruction execution and operand specifier 
evaluation. For instructions requesting Float Quad or Double Float 
context will be a LONGWORD data type. 



1.1.3 BMX 



alu B input Multiplexor 

The BMX provides the data source for the B input to the ALU. The 
GENERAL REGISTERS and the D register are routed to the ALU B input so 
the instruction executions requiring the A. MINUS. B function can be 
performed without swapping the operand from one ALU input to the 
other . 

The PC input is provided to route the address information in the 
ADDRESS SECTION back into the ARITHMETIC SECTION. This also allows PC 
displacement addressing modes to be calculated with the AMX selecting 
the sign extended displacement value. 
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(D) 

The PC or LB input is conditionally selected where source mode 
R.EQL.PC selects the PC otherwise LB input is chosen. The BMX uword 
field must be set to 1. 

(D) 

The RLOG, PCSV input is selected by providing the signal UMSC Read 
RLog and setting the BMX uword. = 0. 

(D) 

The packed floating format puts back together the fraction (D) , the 
exponent (EALU) , and the sign (SD) of the result of the Data path 
floating point operations into VAX floating point data format. 

The LC input allows temporary storage locations to be routed into the 
ALU for ARITHMETIC SECTION operations. 

The KMX input supplies the constants necessary in the execution of 
instructions and evaluation of operand specifiers. 

The MASK input routes the output of the bit MASK generator to the ALU 
for logical operations. BMX data types: 

(D) 

31 00 

_ 

I RBMX I 



(D) 

31 16 15 14 07 06 00 

^ _„__-_________„_________ . 

I D(23:08) | SD I EALU(07:00) | D(30:24) 

1 II I 
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31 __„___...._.. --- 

I LB(31:00) 



31 ___°°„ 

| LC (31:00) | 



31 00 

j PC(31:00) 



(D) 
31 17 16 08 07 00 

n , >| RLOG (08:00) I PCSV (07:00) I 

| 0< I I 

___ __— — ^ ^ ^ ^ ^ oQ 

— — ( 

j 0< >0 I KMX (15:00) 



31 °° 



MASK (31:00) \ 
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BMX CONTROL 

The BMX input is selected by the UBMX field of the UWORD. 



UBMX 

Uword alu B input Multiplexor control field, 3 bits. 

MASK 

1 COND 

2 Packed Floating 

3 LB 

4 LC 

5 PC 

6 KMX 

7 RBMX 



(D) 

When UBMX = 2, a packed floating poi 
taking the fraction position from 
logic, and the exponent from the EALU 
involved both the EALU and the ALU m 
insure that data is available in the 
contains the sign of the destina 
operations. SD had been loaded and c 
the UWORD during execution of 
Conditional selection of PC and LB 
selection of Rlog must be made wi 
signal UMSC Read Rlog. 



nt data type 
the DREG, the 
Due to the 
ust be selected 
ARITHMETIC SECTI 
tion fraction 
ontrolled by the 
floating poi 
is provided wh 
th UBMX=0 and th 



is assent 
sign from 

routing 
for logic 
ON. The 
in floati 

USGN f 
nt instr 
en UBMX= 
e present 



bled by 

control 

delays 

mode to 

SD bit 

ng point 

ield of 

uctions . 

1. The 

s of the 



USGN 

Uword SiGN control field, 3 bits. 

(D) 






NOP 


1. 


SS< — ALU15 




SD< — SD 


2. 


SS< — SD 




SD< — SD 


3. 


SS< — SS 
SD< — SD 


4. 


SS<— SS 




SD< — SS 


5. 


SS<— -ALU15 



SD< — ALU15 
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6. SS< — .NOT.ALU15.XOR.SS 

IF IR[1] ELSE, SS< — ALU15.XOR.SS 
SD< — ALU15 

7. SS< — 
SD< — 

When UMSC = Read Log the RLOG stack and PCSV data is supplied to the B 
input of the ALU. This selection causes a pointer into the RLOG stack 
to be decremented at the end of the Micro-instruction allowing the 
next element of the RLOG stack to be read in a subsequent 
Micro-instruction. The PCSV data remains constant until a new 
instruction is begun. 



1.1.4 SHF 

SHiFter 

The SHF is used as a multiplier to create the correct index values for 
address caculations in INDEX mode specifier evaluations. The index 
value is multiplied by the appropriate number to index tables of byte, 
word, long word, or quad word data entries. For byte organized tables 
the index value is multiplied by 1 (ALU directly with no left 
shift - LO), word tables the index value is multiplied by 2 (left 
shift of 1 - LI), long word tables by 4 (left shift of 2 - L2) , and 
quad word tables by 8 (left shift of 3 - L3) . The datatype 
information is either explicitly determined to be BYTE, WORD, or LONG 
WORD or is determined by the instruction decode logic and is 
controlled by the UDT field. 

The SHF is also used in the execution of multiply and divide and 
compatibility mode rotate and shift instructions. In these cases the 
SHF has the capability of either a left shift by 1 (LI) or a right 
shift by 1 (Rl) or by 2 (R2) with the shift input controlled by the 
USI field. SHF data types: 



ALU 
31 



00 



ALU (31:00) 
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ALU [LI] 
31 01 00 



ALU (30:00) | X | 



ALU[R1] 
31 30 



Determined by- 
USI field 



00 



">l X| ALU (31:01) 

I I 



ALU[R2] 
31 30 29 



X X I ALU(31:02) 



-Determined by USI field 



31 



00 



ALU(31:00) 



ALU[W] - LI 
31 01 00 

I I 

ALU(30:00) | I 



ALU[L] - L2 
31 02 01 00 



I 
ALU (29:00) | 00 



I 
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ALU[Q] or ALUIL3] - L3 
31 03 02 00 



I I 

ALU (28:00) I 000 I 



SHF CONTROL 

The data type of the SHF is selected by the USHF field of the UWORD. 
In three of the shifted data types the shift input is determined by 
the USI field. The UDT field determines which of the remaining 
shifted data types is chosen. 

USHF 

Uword SHiFter control field, 3 bits. 

(D) 






ALU 


1 


ALU [LI] 


2 


ALU [Rl] 


3 


ALU [UDT] 


4 


ALU[R2] 


5 


ALU[L3] 


6 


DO NOT USE 


7 


DO NOT USE 



For USHF = 1, 2, or 4 the USI field determines the shift input 
For USHF = 3 or 5, the shift input is zeroes. 



USI 

Uword Shift Input control field, 3 bits. 

(D) PSL[N] 

1 ALU31 (Do NOT use when writing RA, RB or RC) 

2 

3 

4 

5 Q31 

6 

7 1 

For USHF = 3 the UDT field determines the shift amount. 
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UDT 



Uword Data Type select field, 2 bits, 



LONG WORD 

1 WORD 

2 BYTE 

3 INSTRUCTION DEPENDENT 



ALU[LJ - L2 
ALU[W] - LI 
ALU[B] - LO 
Any of above and ALU[Q] 



- L3 



(D) 



When UDT = 3 the instruction decode logic, SP1CON (02: 00) determines 
the data type which will control the shifting. 



1.1.5 KMX 



Constant (K) Multiplexor 



FK 



Fast constant (K) multiplexor 



SK 



Slow constant (K) rom 



The KMX is 
instructio 
and regist 
mode of 
determined 
evaluated, 
from the d 
the instr 
mode is th 
number of 
Vax mode i 
SP1C0N and 



used to select a constant explicitly specified by the micro 
n or to select an index constant dependent on the data type 
er type of the operand specifier being evaluated. in VAX 

operation, SP1CON (Specifier 1 CONstant) is a number 

from the data type of the operand specifier being 

In 11 Compatibility mode SP1CON is a number determined 

ata type and register type of the source 

uction. SP2C0N (Specifier 2 CONstant) 

e number 1 or 2 determined from the data 

the destination mode/reg. field of the 
s the number 0. SP1CON may be the number 



mode/reg. field of 
in 11 Compatibility 
type and register 
instruction, and in 
1,2,4, or 8. Both 



SP2CON are generated by the instruction decode' logic*. 



The SC input to FK provides a path for the 10 bit data in the EXPONENT 
SECTION to enter the ARITHMETIC SECTION and is also used as a constant 
register in arithmetic operations. 



The fast constants from FK are generally 
decrement data and in the evaluation 
auto-decrement addressing modes. 



used to 
of auto- 



lncrement or 
increment and 



The SK rom provides the remainder of micro program constants used to 
execute instructions, isolate bits or bit fields, provide exponent 
biasing and select shift constants. 
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KMX data types: 



SK 



FK 



15 










00 


1 




itant 






1 


1 








1 


15 






04 03 


00 


1 






1 


SP1< 


1 

CON 1 


1 






1 


1 


15 






02 


01 


00 


1 






1 


SP2 


1 

ICON 1 


1 






1 


1 


15 






04 


03 


00 


1 






1 




1 
* 1 


1 






1 


1 


15 


10 


09 






00 


1 


1 




SC(09:( 


)0) 


I 

1 


1 


1 


1 















KMX, SK, FK CONTROL 

i ^^4-«/i h» t-ho ijkmx field of the UWORD. Constants 



selected from the « Arithmetic SECTION when the ALU is selected 
7o*\l?il Sode^^Ms^eanf thTconstaSts fr-.SK-u.tb. stored in a 

then selected from FK in the subsequent micro instruction) . 
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An alternate method for using the SK would be to select a constant in 
n2v- !!}f ro . ln f truc tion and then (selecting the same constant) in the 
next micro instruction, use it in an arithmetic operation. Care must 
be taken to insure that a micro trap cannot occur between the two 
micro instructions so that the access time of the slow const™? 11 
violated if the second micro instruction is restarted c °™tant is 

(D) 

The only restriction in using the slow constants in the pypdnb-mt 
SECTION is that the NABS (A.MINUS.B) function not be selected. * 

UKMX 

Uword constant (K) Multiplexor select field, 6 bits. 



00 


#8 


01 


#1 


02 


#2 


03 


#3 


04 


#4 


05 


SP1CON 


06 


SP2CON/#0 


07 


SC 


08 


(TBD) 


09 


(TBD) 


0A 


(TBD) 


0B 


(TBD) 


0C 


(TBD) 


0D 


(TBD) 


0E 


(TBD) 


OF 


(TBD) 


10 


(TBD) 


11 


(TBD) 


12 


(TBD) 


13 


(TBD) 


14 


(TBD) 


15 


(TBD) 


16 


(TBD) 


17 


(TBD) 


18 


(TBD) 


19 


(TBD) 


1A 


(TBD) 


IB 


(TBD) 


1C 


(TBD) 


ID 


(TBD) 


IE 


(TBD) 


IF 


(TBD) 


20 


(TBD) 


21 


(TBD) 


22 


(TBD) 


23 


(TBD) 


24 


(TBD) 


25 


(TBD) 
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26 


(TBD) 


27 


(TBD) 


28 


(TBD) 


29 


(TBD) 


2A 


(TBD) 


2B 


(TBD) 


2C 


(TBD) 


2D 


(TBD) 


2E 


(TBD) 


2F 


(TBD) 


30 


(TBD) 


31 


(TBD) 


32 


(TBD) 


33 


(TBD) 


34 


(TBD) 


35 


(TBD) 


36 


(TBD) 


37 


(TBD) 


38 


(TBD) 


39 


(TBD) 


3A 


(TBD) 


3B 


(TBD) 


3C 


(TBD) 


3D 


(TBD) 


3E 


(TBD) 


3F 


(TBD) 
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1.1.6 MASK 

Bit MASK generator 

The MASK is used to generate a bit pattern which can be used to 

isolate fields of bits thru use of the logical functions of the ALU. 

This occurs in the execution of bit field instructions and in the 

memory management process of translating virtual, to physical 
addresses when they are not already translated in the TBUF. 

MASK data type: 

31 00 

_ 

I MASK (31:00) I 



MASK = single bit in a field of ones 

MASK CONTROL 

The MASK generator is controlled by SC(04:00) which is used to address 
a bit position in a long word of ones and insert a zero in that 
position. 

The procedure to generate a mask to retain all bits from bit position 
P and above would involve setting AMX=0 f BMX=MASK, SC=P and performing 
an A. PLUS. B. PLUS. 1 ALU operation. 

To generate a mask to retain 5 bits from position P the settup would 
be: AMX=0, BMX=MASK, SC=P.PLUS.S and ALU=A. PLUS. B. PLUS. 1 . The 
resultant mask could then be added to the previously acquired mask to 
isolate the required bit field. 



1.1.7 LC and RC 

LC - Latch C 

RC - Register set C 

RC is used as a temporary storage area for addresses and operands 
generated during the execution of the micro program. There are 16, 32 
bit temporary registers available and 1, 32 bit storage latch. The 
latch, LC, is used to hold the contents of a previously fetched 
temporary register in RC for use in the ARITHMETIC SECTION. 
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Generally, the contents of RC are fetched in one micro instruction 
into LC and then used by the ALU in the next micro instruction. RC 
may however, be read into LC and used in the same micro instruction if 
the ALU is selected for logical mode. 

LC, RC data type: 

31 ™_ 

I 
I 



LC(31:00) I 



LC, RC CONTROL 

The loading of LC, the writing of RC, and the RC address are 
controlled by the USPO field of the Uword. Refer to section 1.3.8 for 
command code control information. 



1.1.8 LA and LB 

Latch A and Latch B 

RA and RB 

Register set A and Register set B 

RA and RB combine to form a two address port storage location for the 
16 processor GENERAL REGISTERS. These registers are used in the 
addressing mode evaluations and as fast memory storage by the 
instruction set. The two port feature allows fast access to both the 
source register from RB and the destination register from RA in the 
execution of register to register mode instruction. 
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LA and LB are used to hold the contents of a general register which 
had been fetched previously for use in the ARITHMETIC SECTION 
Generally the contents of RA and RB are fetched in one micro 
instruction into LA and LB and then used by the ALU in the next micro 
instruction. RA and RB may however, be read into LA and LB and used 
in the same micro instruction if the ALU is selected for logical mode. 

LA data type: 

31 



00 
LA(31:00) 



LB data type: 
31 



00 
LB(31:00) 



SCRATCH PAD CONTROL 

The three register sets, RC, RB, and RA, and their associated latches, 
LC, LB and LA are controlled by a seven bit opcode field of the UWORD 
designated USPO. This field controls the writing of the scratch pads, 
the loading of the latches, and the address source of the register. 

The address supplied to the RC register set can come from two sources. 
It can be generated explicitly as a register number (RN) in the USPO 
field or it may come from the SC register bits 03:00. 
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The RA and RB sets can be addressed explicitly as a register number 
(RN) in the USPO field or by an Address Code Number (ACN) . The ACN 
number selects the address for RA and RB from several register fields 
of the instruction operand specifiers. In 11 compatibility mode the 
register address comes from either the register field for the source 
mode/register or destination mode register codes in the instruction 
opcode. 

The ACN for the RA and RB sets also selects SC(03:00) as the address 
source. This allows the GENERAL REGISTERS to be sequentially indexed. 

The USPO field also allows individual control of RC from that of RA 
and RB. In these cases when one may be read and the other written the 
contents of RC cannot be interchanged with the contents of RA, RB or 
vice versa in the same micro-instruction. Those USPO codes are 60 to 
7F. 

(D) 

RC register write operations are a. ways Longword data types. 

The RA and RB register write operations are context dependent and is 
controlled by the UDT uword. In operations requiring Float, Quad or 
Double Float context Longword data type will be used. 

UDT 

Uword Data type select field, 2 bits. 



LONGWORD 

1 WORD 

2 BYTE 



32 BITS 
16 BITS 
8 BITS 



3 INSTRUCTION DEPENDENT: Any of above 

When UDT=3, The Instruction decode logic determines to be used in RA 
and RB register write operations. 
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USPO 

Uword Scratch Pad Opcode, 7 bits. 

00 to 05 NOOP 

06 LOAD LC[SC(03:00)] 

07 WRITE RC[SC (03:00)] 

08 to OF LOAD LA,LB[ACN] 



06 05 04 03 02 00 



1 


1 


1 




1 


1 




1 


I 

1 


I 

1 


1 
1 





1 
1 


1 1 
1 


ACN 


1 

1 



10 to 17 LOAD LA[RN] RN=(7:0) 



I I I I I 

I I I 1 I I RN 

I I I I I 



(D) 18 to IF WRITE RA,RB[ACN] 



I I I I I 

I I 1 I 1 I ACN I 

I I I I I 



20 to 2F LOAD LC [RN] 



06 05 04 03 00 

I I I I I 

I I 1 I I RN I 



30 to 3F WRITE RC [RN] 



I I I I 

I I 1 I 1 I R N 
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40 to 4F LOAD LA,LB[RN] 



06 05 04 03 00 



till I 

| 1 I I | RN I 

I I I I I 



50 to 5F WRITE RA,RB[RN] 



till 

I 1 I I 1 I RN 

! I I I 



60 to 6F LOAD LA,LB[R1] 

and WRITE RC[RN] 



I 1 I 1 • I | RN 

I I I I 



70 to 7F LOAD LC [RN] 

and WRITE RA,RB[R1] 



RN 



The ACN field of USPO has two interpretations, one for VAX mode and 
one for 11 compatibility mode. In VAX mode there are three register 
fields in the instruction which are examined. These are SP1R 
(Specifier 1 Register), SP2R (specifier 2 Register), and PRN (Previous 
Register Number). SP1R is the register number from the operand 
specifier currently being examined by the IBUF control logic. SP2R is 
the register number from the byte following the operand specifier in 
IBUF and PRN is the register number from the last operand specifier in 
IBUF. 
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(D) 

In 11 compatibility mode there are two register fields in the 

instruction which are examined. These are the SRC R (SouRCe Register) 
and the DST R (DeSTination Register) numbers found in the source and 

destination mode/register fields. The FPA, Floating Point 

Accelerator, will keep a copy of the RA register. The FPA will 

receive the RA address and a two bit encoded write enable field 

describing the RA write operation data type. 

FPA RA Write Control field 




1 
2 
3 



WORD 

LONGWORD 

BYTE 

NO WRITE 



ACN - VAX mode 
Address Code Number 



(D) 



RA 


address 




RB address 





SP1 R 




SP1 R 


1 


SP2 R 




SP2 R 


2 


SP2 R 




SP1 R 


3 


PRN 




PRN 


4 


PRN.PLUS.l 


PRN.PLUS.l 


5 


SC(03: 


00) 


SC(03:00) 


6 


SP1 R. 


PLUS.l 


SP1 R. PLUS.l 


7 











ACN - 11 compatibility mode 



RA 


address 




RB address 





SRC R 




SRC R 


1 


DST R 




DST R 


2 


DST R 




SRC R 


3 


SRC R 




SRC R 


4 


SRCR.OR.l 


SRCR.OR.l 


5 


SC(03: 


00) 


SC(03:00) 


6 


SRC R. 


PLUS.l 


SRC R. PLUS.l 


7 
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1.1.9 RLOG and PCSV 
RLOG - Register LOG stack 

PCSV - Program Counter SaVe register 

The RLOG stack and PCSV register provide sufficient information to the 
microcode so that the contents of the general registers may be 
restored to their original values in order that an instruction may be 
restarted. If a memory management fault occurs which requires a 
macro-level trap routine to be run it is necessary to back-up the 
general registers that had been auto-incremented and auto-decremented 
during the execution of the instruction causing the fault. 

The RLOG stack keeps track of the register numbers and constant values 
used to update the registers in specifier evaluations. There are 16 
locations in the RLOG stack and at each instruction fetch a pointer 
into the stack is initialized and an RLOG empty flag asserted. When 
the micro-code fault routine reads the RLOG the pointer is decremented 
and the next entry in the stack becomes available. 

The PCSV register saves the lower 8 bits of the PC at the time an 

instruction is fetched. Since no instruction is longer than 256 

bytes, the entire 32 bit starting PC may be reconstructed if a fault 
occurs. 

RLOG data type : 
(D) 

16 15 12 11 08 

III I 

I ADD/SUB | KMX (03:00) I RA ADDRESS BITS I 
I I I (03:00) | 



PCSV data type: 
07 00 



PC(07:00) I 

I 
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RLOG CONTROL 

The RLOG stack is written when the UALU field specifies an RLOG update 
operation. If the operation is A. PLUS. B (RLOG UPDATE), RLOG08 is set 
to a one, otherwise it is set to zero. 

Whenever the UMSC field selects the Read RLOG function, the current 
value is read out of the stack and the pointer is incremented at the 
end of the micro-instruction. 

PCSV CONTROL 

Each time an instruction is fetched, the PCSV register gets the low 8 
bits of the PC. 



1.2 EXPONENT SECTION 

The EXPONENT SECTION is used to perform exponent processing in 
parallel with fraction processing in the ARITHMETIC and DATA SECTIONS 
of the Data Path when floating point instructions are being executed. 
When processing exponents the 10 bit exponent path is interpreted as 
an 8 bit exponent and a 2 bit overflow/underflow code. 

The EXPONENT SECTION is also used for controlling the SC register when 
it is used to generate masks, to address RA, RB, or RC, to address 
processor registers, or to be used as a shift value in the DATA 

SECTION. 



1.2.1 EALU 



Exponent Arithmetic and Logic Unit 



The EALU 
consists 
absolute 
are used 



performs the processing of data in the EXPONENT SECTION. It 

of an ALU circuit with fast carry look ahead, a negative 

value look up rom and a multiplexor. The rom and multiplexor 

in NABS (A. MINUS. B) mode to provide a shift value in floating 



point arithmetic alignment. 



EALU data type: 



09 



00 



EXP D(09:00) 
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EALU CONTROL 

The EALU function is controlled by the UEALU field of the UWORD and is 
defined as arithmetic or logical. The only restriction on EALU source 
data is that the NABS (A. MINUS. B) function not be used when a slow 
constant is being used from KMX unless the proper set-up time has been 
met as described in section 1.3.5. 

UEALU 

Uword Exp. Arithmetic and Logic Unit control field, 3 bits. 

(D) 






A 


1 


A.OR.B 


2 


A.AND.B 


3 


B 


4 


A. PLUS. B 


5 


A. MINUS. B 


6 


A. PLUS. 1 


7 


NABS (A. MINUS. B) 



1.2.2 EAMX 

Ealu A input Multiplexor 

The EAMX provides the data source for the A input to the EALU. 
Whenever the STATE register is selected as the data source, the STATE 
register is loaded in the same micro instruction. 

EAMX data types: 

09 00 



SC(09:00) 



09 08 07 00 

I I 

|0 1 STATE (07:00) 
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EAMX CONTROL 

The EAMX input is selected by the UMSC field of the Uword. Whenever 
the UMSC field selects the LOAD STATE REG code the EAMX is switched so 
that the STATE REG is fed to the input of the EALU. At the end of 
that micro instruction, the STATE register is loaded. At all other 
times the SC register is selected at the EAMX. 



1.2.3 EBMX 

Ealu B input Multiplexor 

The EBMX provides the data source for the B input to the EALU. The 
EBMX receives either the exponent from the FE register or the exponent 
field from the AMX when the EXPONENT SECTION is used for exponents 
processing. 

Constants from the KMX or shift values from the control logic of the 
DAL are used as data sources for the EBMX so that a shift count in SC 
may be operated on. Constants may also be selected to set or clear 
flags in STATE. 

The SHF VAL is a hardware generated number of left shifts necessary to 
normalize the contents of the D register. The normalized number is 
obtained by shifting to the left of the most significant "1" in the D 
register to the BIT 31 position. This process can be accomplished in 
one machine cycle with the UDK uword = D enabling the D register to be 
updated with the normalized number. 

EBMX data types: 

09 _ 00 

_ 

I FE (09:00) I 



09 



00 



KMX (09:00) 
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(D) 

09 08 07 00 

. . - - 

| I I AMX (14:07) I 



09 05 04 00 

. „_.____„_.._— ^ 

| o< >0 I SHF VAL (04:00) I 

I _" _ _ I _____ 1 

EBMX CONTROL 

The EBMX is controlled by the UEBMX field of the UWORD. 

UEBMX 

Uword Ealu B input Multiplexor control field, 2 bits. 
(D) FE 

1 KMX 

2 AMX EXP 

3 SHF VAL 



1.2.4 FE 

Floating Exponent register 

The FE is used to hold exponents or temporary values for processing in 
the EXPONENT SECTION. 

FE data type: 

09 °° 

I ."" • 

LOAD FE I EXP D(09:00) I 



DATA PATH SPECIFICATION p a 1 _ 3Q 

FE CONTROL 

The loading of the FE register is controlled by the UFEK field of the 
UWORD. 



UFEK 

Uword Floating Exp. control (K) field, 1 bit. 

HOLD 

1 LOAD 



1.2.5 STATE 



STATE register 



The STATE register contains 8 flag bits which are generated by the 
micro program to be used in program flow control. Each four bit qrouD 
of the STATE register is used as a 16 way branch condition in the 

of C ££ ^?M enC r.u SeCti ° n ° f the CPU * ^ usin 9 the ^gical operations 
of the EALU and the constants from KMX a micro instruction may set or 
clear individual bits in the STATE register. 



STATE data type: 

07 



00 



LOAD STATE | EXP D (07:00) | 

1 I 



STATE CONTROL 

The loading of the STATE register is controlled by selecting the LOAD 
STATE REG of the UMSC field of the UWORD. 9 
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1.2.6 SMX 

Shift count Multiplexor 

The SMX provides a data link from the ARITHMETIC SECTION into the 
EXPONENT SECTION and allows either a 10 bit data field or an 8 bit 
exponent to be routed to the SC register from the ALU. 

The SMX also has FE as a data source so that the values in FE and SC 
can be swapped in a single micro instruction. 

The EALU data source of the SMX allows processing of the SC register 
in the EALU for incrementing or decrementing values in the SC. 

SMX data types: 



09 




00 


1 1 
| EXP D(09:00) 1 

1 1 


09 




00 


1 1 
I FE(09:00) 1 

1 1 


09 




00 


1 1 
| ALU(09:00) 1 

1 1 



09 08 07 00 

I I I 

| I I ALU (14:07) 

I I I 



DATA PATH SPECIFICATION p age !_ 32 

SMX CONTROL 

The SMX data type is selected by the USMX field of the UWORD. 

USMX 

Uword Shift count Multiplexor control field, 2 bits. 

EALU 

1 FE 

2 ALU 

3 ALU EXP 

1.2.7 SC 

Shift Count register 

The SC is used extensively in the CPU for different control functions. 
The ID BUS control section uses SC(05:00) to address an internal 
processor register word. The DATA SECTION of the Data Path uses 
SC (09, 04: 00) to control the shift amount in the DAL. The ARITHMETIC 
SECTION uses SC(04:00) to generate a bit mask and SC(03:00) to form a 
register address in the RA, RB f and RC register sets. 

The SC is also used to store exponents in the EXPONENT SECTION. 
SC data type: 

09 00 

^ _ —__„._„_ ___ _ 

LOAD SC | SMX (09:00) I 

SC CONTROL 

The loading of SC is controlled by the USCK field of the UWORD. 

USCK 

Uword Shift Count control (K) field, 1 bit. 

HOLD 

1 LOAD 
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1.3 DATA SECTION 



The 



DATA SECTION controls the shifting, the byte 
unpacking of floating data types, and the moving of 
the DATA CACHE or ID BUS interface. 



alignment, the 
data to and from 



1.3.1 DFMX 



Data Format Multiplexor 



The DFMX is the input link from the ARITHMETIC to the DATA section and 
generates data types in either integer or unpacked floating formats. 
In unpacked floating format the sign and exponent fields are stripped 
off and the fraction bits assembled in the correct sequence with zero 
guard bits and the hidden one inserted. 



Integer format: 



31 



00 



SHF(31:00) 



Unpacked floating format: 
31 30 29 23 22 



07 06 



00 



I I I 

I 1 I SHF(06:00) I 
I I I 



SHF(31:16) 



I I 

10 I 

I I 



DFMX CONTROL 

The DFMX formats are controlled by the UQK and UDK fields of the 
UWORD. If either control field calls for unpacked floating data the 
DFMX will select that format, otherwise integer format will be used. 
Refer to sections 1.5.5 and 1.5.6 for control codes. 



DATA PATH SPECIFICATION Page 1-34 

1.3.1.1 BUS DFMX - 

This is a tri-state bus that provides a data link from the Arithmetic 
Section, DFMX, or from the Floating Point Accelerator to the Data 
Section. 

The Accelerator uses this path to sample RA scratch pad write data or 
route data into the Datapath via the D register or Q register. 

Tri-state control of the Bus DFMX is accomplished by programming the 
UDK or UQK uword fields. Accelerator control is made by selecting 
UDK=A or UQK=B. Arithmetic section control, DFMX, is the default 
programming of the above uword codes. 
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1.3.2 QMX 

Q register Multiplexor 

The QMX provides paths for loading the Q register from either the 
ARITHMETIC SECTION via the DFMX , from the Floating Point Accelerator, 
from the D register such that the ARITHMETIC SECTION may be 
simultaneously used for other operations; from the ID Bus or with the 
generation of a constant of six in each 4 Bit NIBBLE for use in 
decimal arithmetic. Each NIBBLE X constant is generated by the lack 
of an ALU byte X carry. 

QMX data types: 
31 00 



1 
1 
1 


BUS 


DFMX (31:00) 


1 
1 
1 


31 






00 


1 1 
| D(31:00) 1 

1 1 


31 






00 


i ! 

| ID(31:00) 1 

1 1 



(D) 
31 00 



1 

1 6 
1 


I 

1 6 

1 


1 

1 6 

1 


1 

1 6 

1 


1 

1 6 

1 


1 

1 


6 


1 

1 6 

1 


1 1 
1 6 1 
1 1 



QMX CONTROL 

The QMX data type is selected from the UQK field of the UWORD. 



DATA PATH SPECIFICATION Page 1-36 

1.3.3 DMX 

D register Multiplexor 

The DMX provides the necessary paths for loading the D register from 
the ARITHMETIC section via the DFMX, from the Floating Point 
Accelerator, the CACHE MEMORY interface via the MD BUS, distinct 
sections of the total CPU and from the DAL. 

DMX data types: 

31 00 

I 7 

I MD BUS(31:00) I 



31 00 

^ ^ .___ _________ 

D(07:00) | D(15:08) | D(23:16) I D(31:24) 

I I I 



31 00 



1 1 

1 BUS DFMX (31:00) I 

1 1 


31 




00 


1 1 
1 DAL (31: 00) 1 
1 1 



DMX CONTROL 

The DMX data types are selected from the UDK field of the UWORD. 
Refer to section 1.5.6 for control codes. 
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1.3.4 DAL 

Data ALignment 

The DAL allows the D register contents to be shifted a maximum of 32 
positions to the right with the least significant end of the Q 
register shifted in or 31 positions to the left with the most 
significant end of Q shifted in. Positive shift numbers will cause 
left shifting, negative shift numbers (two's complement notation) will 
cause right shifting, negative zero value will cause a 32 bit shift (Q 
register), and positive zero will result in D unshifted. 

The DAL is used to perform the shifting operations required in the 
execution of bit field, multiply, divide, shift and decimal arithmetic 
instructions. It is also used to isolate bit fields in the virtual to 
physical address translation process. 

DAL shift range: 

Shift amount = 000000 (NO SHIFT) 
(D) 

31 00 

I I 

I D(31:00) I 



Shift amount = 011111 (LEFT 31) 

(D) 

31 30 00 

I I 

I D00 I Q(31:01) 

I I 

Shift amount - 100000 (RIGHT32, Q) 

(D) 

31 00 

I 

I 0(31:00) 
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Shift amount = 111111 (RIGHT 1) 

(D) 
31 30 00 

I I I 

I Q00 | D(31:01) I 

I I I 



Shift amount = 100001 (RIGHT 31) 

(D) 
31 01 00 

I I I 

I Q(31:01) I D31 I 

I I I 



DAL CONTROL 

The DAL with the shift amount selected by either the contents of SC or 
by a shift value determined by a hardware look-up may be specified by 
the UDK field of the UWORD. 

When the UDK field specifies that the D register be loaded with the 
contents of the Q register the DAL is selected for a RIGHT shift of 32 
and the DMX selects the DAL. Refer to section 1.5.6 for control 
codes. 



1.3.5 Q 

Q register 

The major function of the Q register is to be used with the D register 
to hold data structures which are larger than 32 bits. This occurs in 
the execution of field and double floating instructions. 

The Q register also is used to hold the multiplier and quotient bits 
in the execution of the multiply and divide instructions. 

During evaluation of instruction operands the Q register is used to 
hold the first operand while the next one is being evaluated. In 
general, Q is used as a temporary storage location for data generated 
in the ARITHMETIC SECTION. 
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Q register data types: 

Load Q 

31 00 

___ __________ ^ 

| QMX (31:00) I 



Shift left (single shift) 

31 01 00 

_ _ __________ ___________ ^ ^ 

| Q(30:00) I X I 

I I I 



I 
I 

Determined by 

USI field 



Shift left (double shift) 

31 02 01 00 

_ _____________________ ^ ^ 

| Q(29:00) I X X I 



^ ^ 



I I 

Determined by 

USI field 
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Shift right (single shift) 
31 30 00 

I I I 

I X I Q(31:01) I 

I I I 

I 

Determined by 

USI field 
Shift right (double shift) 

31 30 29 00 

I" ~ ~~l I 

I X X I Q(31:02) i 

I I __ _l 

I I 

Determined by 

USI field 

Q CONTROL 

The Q register loading and shifting is controlled from the UQK field 
of the UWORD with shift inputs selected by the USI field. 

UQK 

Uword Q register control (K) field, 4 bits. 






HOLD 


1 


DOUBLE SHIFT LEFT 


2 


DOUBLE SHIFT RIGHT 


3 


Reserved 


4 


Reserved 


5 


SINGLE SHIFT LEFT 


6 


SINGLE SHIFT RIGHT 


7 


Reserved 


8 


LOAD SHF (Integer format) 


9 


LOAD SHF (Unpacked floating format) 


A 


LOAD Decimal Const (NIBBLE ALU carry 


B 


LOAD ACC DATA 


C 


LOAD D 


D 


Reserved 


E 


LOAD ID BUS 


F 


LOAD ZEROES 



dep) 



The shift input to the Q register is selected by the USI field 
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USI - Q input 

Uword Shift Input control field, 3 bits. 

(D) ALU CARRY 31 (to be used for single shift only) 

1 Q31 

2 D31 

3 

4 

5 ALU CARRY 31 (To be used for single shift only) 

6 

7 1 



1.3.6 D 

D register 

The D register acts primarily as the data interface connection between 
the DATA PATH and Memory or the DATA PATH and remotely located 
sections of the CPU and FPA. When used for ID BUS write transfers, 
odd parity is generated on a per byte basis. Parity on data received 
from the ID is not checked. 

The D register is used in conjunction with the Q register to hold data 
structures larger than 32 bits. It may also be used as a temporary 
storage location for data generated in the ARITHMETIC SECTIO.. D 
register data types: 

LOAD D 
31 00 

I I 

I DMX (31:00) I 

I I 



Shift left (single shift) 

31 01 00 

I I 

| D(30:00) I X 

I I 



Determined by- 
USI field 
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Shift left (double shift) 
31 02 01 00 

I D(29:00) |X XI 



I 



31 30 



I I 



Determined by- 
USI field 



Shift right (single shift) 



00 



I I 

I X i D(31:01) 



-Determined by 
USI field 

Shift right (double shift) 



31 30 29 00 



I 



D(31:02) 



-Determined by 
USI field 



D CONTROL 



The D register loading and shifting is controlled from the UDK field 
of the UWORD with shift inputs selected by the USI field. 
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UDK 

Uword D register control (K) field, 4 bits. 

HOLD 

1 DOUBLE SHIFT LEFT 

2 DOUBLE SHIFT RIGHT 

3 Reserved 

4 SINGLE SHIFT LEFT if .NOT, ALU CARRY. ELSE LOAD SHF(INT FORM). 

5 SINGLE SHIFT LEFT 

6 SINGLE SHIFT RIGHT 

7 Reserved 

8 LOAD SHF (Integer format) 

9 LOAD SHF (Unpacked floating format) 
A LOAD ACC DATA 

B LOAD D NIBBLE SWAP 

C LOAD Q 

D LOAD D (Shifted by SC (09, 04:00)) 

E LOAD D (Shifted by SHF VAL) 

F LOAD ZEROES 

(D) 

The shift input to the D register is selected by the USI field. The 
CACHE and SBI Subsystem can load the D register only when the UDK 
uword = 0. 

USI - D input 

Uword Shift Input control field, 3 bits. 

Q31 

1 Q00 

2 

3 

4 

5 Q31 

6 SAVED ALU01/ALUO0 

7 SAVED ALU01/ALU00 

If UDK=D the D register is shifted in the DAL by the value specified 
by SC09 and SC(04:00). 

For UDK=E the D register is shifted in the DAL by a value determined 
by a hardware lookup table. This is used for the normalization of 
fractions and is completed in 1 machine cycle. 
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When UDK=C, the DAL is selected for a shift of 32 which produces the Q 
register on its outputs. 

When USI=6 or 7 and the D register is selected for a double shift, 
ALUOO is shifted into D on the first shift and ALU01 on the second 
shift of the machine cycle. If a single shift has been selected, 
ALU01 will be shifted in. 

If a memory read operation is specified by the UDK fields of the UWORD 
the D or Q register is loaded with the contents of the Memory Data 
Bus. Data is stored in memory or byte boundaries but accessed on the 
MD BUS on a long word boundary. To load the D register with the 
correct data alignment a right shifting procedure is done by the 
MDBAL. 



1.3.6.1 MDBAL - 

Memory Data Byte Alignment 

The MDBAL provides the correct data alignment from the MD BUS for use 
in the Data Path. 

MDBAL CONTROL 

The right shifting process is controlled by two bits of the Virtual 
Address register, VA(01:00) . These two bits specify the least 
significant byte position of a memory read access and the number of 
right shifting of bytes required for loading into the D Register. 

MD Bus shift right positions 

SHFfRO]* 
SHF[R8] 
SHF[R16] 
SHF[R24] 

If the memory control field of the UWORD specifies a memory read 
operation, the D register is loaded with the contents of the MD BUS. 
If the data length requires a second memory reference due to the 
starting byte of the Longword address being read, a mask is generated 
to selectively enable the loading of bytes into the register in order 
to assemble the entire data type being read. Data on the MD BUS will 
be rotated according to the byte address used for the reference. 



VA(01 


:00) 











1 


1 





1 


1 



[RX] x being equal to the bit positions shifted right. 



ADR(01:00) 



I 3 I 



/ 



/ 



/ 



/ 



\ 



\ 



\ 



\ 



DATA 

TYPE: I L I I W I I B | 

I \ I 

I \ I 

LOAD I \ I 
MASK: 1111 1111 1111 
I \ 

I \ 

I \ 

2ND | \ 

REF: 

IADR+4I | ADR +4 I 



LOAD 

MASK: 1110 



0010 



I MEMORY 
I READ 



I 2 I 



/ 



/ 



/ 



/ 



\ 



\ 



\ 



\ 



\ 



I L I I W | I B I 

I I I 

I I I 

I I I 

1111 1111 1111 



IADR+4 | 



1100 



I 1 I 



/ 



/ 



/ 
L 



\ 



\ 



\ 



\ 



\ 



I W | I B I 

I I I 

I I I 

I I I 

1111 1111 1111 



I ADR+4 



1000 
Figure 1-2 
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ADR 01, 00 



MD BUS DATA: 








1 



1 


1 BYTE 


3/7 


1 BYTE 


2/6 


1 BYTE 


1/5 


1 BYTE 


0/4 | 























1 BYTE 


0/4 


I BYTE 


3/7 


1 BYTE 


2/6 


1 BYTE 


1/5 | 




















1 


1 BYTE 


1/5 i 


1 BYTE 


0/4 | 


1 BYTE 


3/7 | 


1 BYTE 


2/6 | 




















1 


1 BYTE 


2/6 


1 BYTE 


1/5 1 


1 BYTE 


0/4 


1 BYTE 


3/7 | 



1.3.7 D PGEN 



D reg Parity GENerator 

The D PCGEN circuit generates one parity bit for each byte 
register to be transmitted along with data on the IB BUS. 
is generated. 



in the D 
Odd parity 



1.3.8 BAL 



Byte ALignment 



The BAL is used to rotate the contents of the D register so that the 
bytes are aligned with the byte address in which data is to be 
written. A byte mask is generated by the hardware to control which 
bytes in a long word address are to be written into memory or as an 
indication as to what bytes are being read. 
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BAL data types: 

ADR(01,00) = 
35 34 33 32 31 24 23 16 15 08 07 00 



1 

1 P3 
1 


1 

1 P2 

1 


1 

1 PI 

1 


1 

1 P0 

1 


1 

1 D BYTE 3 

1 


1 

1 D BYTE 2 

1 


1 

I D BYTE 1 

1 


1 1 
I D BYTE | 
1 1 



I 
\ / 

\ / 

D Byte Parity 
ADR (01,00) = 1 



I I I I I I I I I 

I P2 | PI | PO | P3 | D BYTE 2 | D BYTE 1 I D BYTE | D BYTE 3 I 
I I I I I I I I I 

I I 

Y / 

\ / 

D Byte Parity 
ADR (01, 00) = 2 



I I I I I I I I I 

I PI I PO I P3 | P2 | D BYTE 1 I D BYTE | D BYTE 3 I D BYTE 2 I 
I I I I I I I I I 



\ / 

\ / 

D Byte Parity 
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ADR(01,00) = 3 



I I I I I I I 

PO | P3 | P2 | PI |D BYTE I D BYTE 3 I D BYTE 2 I D BYTE 1 



I I 



I I 

\ / 

\ / 

D Byte Parity 

BAL CONTROL 

The byte shift value is selected by the ADR address bits 01 and 00, 
and the BAL output drivers are turned on by the memory control logic 
in the Data Cache control. 

A four bit byte mask is generated to enable the writing of individual 
bytes into memory. For long word data types at ADR (01: 00) =1, 2, or 
3 or word data types of ADR(01:00) = 2 or 3 a second memory reference 
must be performed to complete the data write operation, in which case 
a second byte mask must be generated. A code in the UMSC field of the 
UWORD specifies the second reference of this data alignment procedure. 

BYTE MASK field is also generated during Memory read operations. 



ADR (01:00) 



I 3 I 



/ 



/ 



/ 



/ 



\ 



\ 



\ 



\ 



\ 



DATA 

TYPE: I L | I W I I B I 



\ 



I 
BYTE I 
MASK: 1000 

I 



2ND 
REF: 



\ I 

\ I 
1000 1000 
\ 
\ 
\ 
\ 



I ADR+4 



IADR+4 



MEMORY READ 
OR WRITE 
XFERS 



I 2 | 



/ 



/ 



/ 

/ 
/ 

I L | 

I 

I 



/ 



\ 



\ 



W 



I 



1100 1100 

I 

I 



\ 
\ 
\ 

I B I 

I 
I 
I 
0100 



I ADR+4 | 



/ 



/ 



/ 



/ 



\ 



\ 



\ 



\ 



\ 



LI I W I I B I 

I I I 

I I I 
I I I 

1110 0110 0010 

I 
I 
I 
I 



I ADR+4 



I I 



/ 



\ 



/ 



/ 
/ 

L 

I 
I 
I 
1111 



\ 



\ 



I I W I 



I 
0011 



\ 
\ 

! B | 

I 

I 

I 

0001 



> 
> 

> 

"-3 

SB 

CO 
W 

o 

M 
•»> 
1-1 

o 
> 
-3 

M 

o 

z 



(1> 



BYTE 
MASK: 



0111 



0001 



0011 



0001 
Figure 1-3 
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•is. 



DATA PATH SPECIFICATION p age j^q 

1.3.9 RAMX 

Register Amx Multiplexor 

The RAMX is a link for the DATA SECTION to provide data to the ALU A 
input of the ARITHMETIC SECTION. 

RAMX data types: 



31 




00 


J ! 
I D(31:00) | 

1 1 


31 




00 


I Q(31:00) | 

1 1 



1.3.9.1 RBMX - 



Register Bmx Multiplexor. 



The RBMX is a link for tfte DATA SECTION to provide data to the ALU B 
input of the ARITHMETIC SECTION. 

RBMX data types: 



31 




00 


1 | 
| Q(31:00) | 

1 1 


31 




00 


J i 

1 D(31:00) | 

1 1 
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RAMX and RBMX Control 

The data type of the RAMX and RBMX is selected by the URMX field of 
the UWORD. 

URMX 

Uword Register Multiplexor control field, 1 bit. 
RAMX RBMX 

D Q 

1 Q D 



1.4 ADDRESS SECTION 

The ADDRESS SECTION of the Data Path is used to keep the virtual 
address for operand references, the program counter, and the 
instruction buffer address. 

Each address register has counting ability so that the commonly used 
address arithmetic performed does not require use of the ARITHMETIC 
SECTION. 



1.4.1 VIBA 

Virtual Instruction Buffer Address counter 

The VIBA holds the address for the instruction stream data being 
fetched by the instruction buffer (IBUF) control logic. 

VIBA data type: 

LOAD 
31 00 

_ ________________ ^ 

| ALU(31:00) I 

I I 



VIBA CONTROL 

The loading of the VIBA is selected by a control code in the UIBC 
field of the UWORD. This takes place whenever the instruction 
execution changes sequence such as in the case of JUMP and successful 
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BRANCH instructions or as in the initiation of a trap or interruDt 

routine. r T 

The IBUF control logic will increment the VIBA (by 4) whenever it has 
successfully fetched instruction data. 



1.4.2 VA 

Virtual Address counter 

The VA holds the address which the micro program generates in the data 
path to read or write a memory location. The VA will primarily 
contain a virtual address which must be converted to a physical memory 
address by the TRANSLATION BUFFER. y 



At other times the VA may hold a physical memory address which has 
been generated by the micro program during the translation process or 
wnen the memory management mechanisms are turned off. 



The VA may also be used to index into the TBUF whenever the TBUF is 
being updated or invalidated by the micro program. During the 
execution of the PROBE instruction the indexing is used to determine 
if an access violation would occur if the memory reference to that 
virtual address was actually performed. 

The VA also provides a load path from the ARITHMETIC SECTION into the 
VA data type: 

_H 00 

^ --_-_. _, __ _ _______ .______„ 

I 
I 



I 
ALU(31:00) | 



VA CONTROL 



The loading of the VA is controlled by the UVAK field of the UWORD. A 
command code in the UACK field specifies that the VA counter be 
incremented by four. The load operation will override the 
incrementation if both functions are selected simultaneously. 
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UVAK 



Uword Virtual Address control (K) field, 1 bit, 



HOLD 

1 LOAD 



1.4.3 VAMUX 



Virtual Address Multiplexor 

The VAMUX address interface logic formats the address into either the 
vax address format or the 11 compatibility format and selects either 
the VA or the VIBA as the address source. 

VAMUX formats: 

VAX MODE 

31 00 

^ ^^^^ ______ _ 

I VA(31:00) | 

I I 

31 02 01 00 

^ -—_—_.__--____._______ 

I VIBA(31:00) I | I 
L III 

II COMPATIBILITY MODE 

31 16 15 00 

I I """" I 

| < >0 I VA(15:00) I 

l_ I I 

31 16 15 02 01 00 

I I III 

| < >0 | VIBA(15:02) I | | 

I I III 
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VAMX CONTROL 

The Compatibility Mode bit in the PSL register controls which address 
format is selected in the VAMX multiplexor. 

The address select is provided by a signal from the TBM. The VA is 
selected as the address source whenever the micro program is 
requesting a memory reference. At all other times, the micro program 
selects the VIBA as the address source and the IBUF control logic is 
allowed to use the cycle to request a memory transfer. 



1.4.4 PC 

Program Counter 

The PC is used to hold the address of the opcode each time a new 
instruction execution is started, and is incremented as each of the 
operand specifiers are being evaluated. 

PC data type: 

31 04 03 00 

^ _______ „___ __ _ _ 

I 
I 



PCMX (31:04) | PCAMX (03:00) | 

I I 



PC CONTROL 



The loading of the PC is controlled by the UPCK field of the UWORD. 
Command codes in the UPCK field specify incrementation of the PC by l] 
2, 4 or N. The value N is determined by the instruction buffer 
control logic and is used to increment the PC beyond instruction 
stream bytes associated with each specifier. 
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UPCK 



Uword Program Counter control (K) field, 3 bit, 






NO-OP 


4 PC<~PC+1 


1 


PC<~VA 


5 PC<— PC+2 


2 


PC<~IBA 


6 PC<~PC+4 


3 


VA< — VA+4 


7 PC<~PC+N 



1.4.5 PCADD 

Program Counter ADDer 

NMX 

Number Multiplexor 

The PCADD and NMX allow the numbers 1, 2, 4 and N to be added to the 
PC register. The number N comes from the Instruction buffer control 
and may be the numbers 1, 2, 3, and 5. The four bit output of the 
PCADD is loaded into the lower four bits of the PC register and if a 
carry results the upper 24 bits of the register is incremented. 

PCADD data type: 



03 



00 



PC (04:00) .PLUS. NMX (3:0) 



NMX data type: 



03 



02 



00 



#1,2,3,4, or 5 



DATA PATH SPECIFICATION Page 1-56 

PCADD, NMX CONTROL 

The PCADD and NMX are controlled by the UPCK field of the UWORD. 

1.4.6 PCMX 

Program Counter Multiplexor 

PCAMX 

PC Adder Multiplexor 

The PCMX and PCAMX provide the data input to the PC register. 
Whenever the PC register is being loaded the PCAMX selects the PCMX 
for the low 4 bits and the PCMX selects either the VA register or the 
VIBA register. 

Whenever the PC register is counted the PCAMX selects the PCADD to be 
loaded into the low 4 bits of the register while the upper 24 bits of 
PC may be incremented. 

PCMX data types: 
31 00 



I 1 

1 VA(31:00) | 

1 1 


31 




02 


01 


00 


1 
1 
1 


VIBA(31:00) 




1 

1 o 

1 


1 1 

1 | 

1 1 
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PCAMX data types: 



03 



03 



PCMX, PCAMX CONTROL 



PCMX (03:00) 



PCADD (03:00) 



00 



00 



The PCMX and PCAMX are controlled by the UPCK field of the UWORD 
field. 



CHAPTER 2 
MICRO SEQUENCER SPECIFICATION 



The purpose of the Micro Sequencer is to control CPU operations and 
functions and control the Micro Word Fields to ensure known operation 
during Powering Up, Powering Down, Micro Traps, Stalls, Micro Word 
ECOs, and console operations. 



2.1 NORMAL MODE 

The Micro Word is controlled by the Micro Program Counter address 
lines. (UPC) The Branch Enable field (BEN) and/or the Jump field (J 
Field) control the next Micro Address (NUA) which forms the UPC. 



2.2 MICRO ECO CONTROL (UECO) MODE 

The purpose of the UECO logic is to allow Micro words that need 
changes to be updated and written into Writeable control store (WCS) . 
This greatly reduces the requirements for changing many Prom Chips by 
programming only one FPLA per CPU. 

When a uword ECO is needed, the UPC address of the Prom uword is put 
into an FPLA. In addition, a new address to be used is put into the 
FPLA which references WCS. 

During CPU operation and when the UPC matches an address in the FPLA, 
the FPLA outputs a signal to the stall control and Pico sequencer. 
Upon receipt of an ECO Dispatch signal a clear uword fields signal and 
an abort cycle signal are generated. These signals create in effect a 
NO-OP cycle in which to allow a new uword from WCS to be accessed. 

The FPLA output is clocked into the UECO register at CPT of the 
NO-OP cycle. This register holds the lower six bits of the WCS 
address which contains the program patch. The UMX select lines then 
allows the UECO register to be the source for the UPC address lines. 
WCS is then accessed and the new uword is clocked into the uword 
registers at CPTO of the next cycle. 
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Control is returned to the normal Prom control store sequence by the 
Ben and J Fields of the uword from WCS. 

The eight bit output from the FPLA is used as follows: 

07= not presently used 

06= signals the ECO sequence to begin 

<05:00>= the UECO address in WCS to be accessed. 



UECO FLOW 



I 
I 
I 
I 
V 
***************** 

* * 

* UINSTR A * 

* * 
***************** 

I I 



UECO FLOW 



NORMAL >I 



***************** 

* UINSTR B * 

* NEEDS *<- 

* ECO * 
***************** 

I 

I 
***************** 

* * 

* UINSTR C *<- 

* * 
***************** 

I 

I 
V 



***************** 

* * 

* NO-OP UINSTR * 

* * 
***************** 



BYPASSED 

UINSTR 



***************** 

* UECO'D UINSTR * 
*FOR UINSTR B IN* 

* WCS * 
***************** 



NO-OP UINSTR TO 
ALLOW TIME TO 
ACCESS THE WCS 
ADDRESS WITH THE 
REVISED UINSTR 
B 



REVISED UINSTR B. 
J AND BEN FIELDS 
ARE USED TO SELECT 
ADDRESS FOR UINSTR C 
AND GO BACK NORMAL 
PROM UINSTR. 



Figure 2-1 
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2.3 MICRO TRAP (UTRAP) MODE 

Utraps are due to faults or errors in the CPU. Upon receiving a utrap 
signal the Micro sequencer control (USC) sends out the signals clear 
uword and abort cycle, to other CPU subsystems. These signals create 
NO-OPs and allow time to direct the CPU to error handling micro code. 

The utrap signal is clocked into the Pico sequencer at CPTO. The 

utrap cycle then selects the UMX to make the vector address the UPC 

address for the new uword to be clocked into the users registers at 
the next CPTO. 

The utrap cycle clears the Ben,USUB, and JField registers on the USC. 
Ben 10 (HEX) is then enabled to allow the CEH module to control the 
NUA bits <03:00> as per the type of utrap. 

The utrap vector address areas are: 

Prom 0100 upto 010F (HEX) 

WCS 1100 upto 110F (HEX) 

The console can direct the utrap vector to WCS when the 
CIBN UPC 12(1) H bit is set in the console. 

The UTRAP vectors are in HEX and their functions are: 

X100 System Init 

X101 Unaligned Data Trap 

X102 Page Trap 

X103 M Bit 

X104 Protection Violation 

X105 Translation Buffer Miss 

X106 Reserved Floating Operand 

X107 Trans. Buffer Parity Error 

X108 Cache Parity Error 

X109 Reserved 

X10A Reserved 

X10B Reserved 
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X10C RDS Error 

X10D Time Out 

X10E Odd Address Error 

X10F Control Store Parity Error 



When a utrap is iniated by the hardware, the Micro Program counter 
save register (UPCSV) contents are pushed onto the Micro Stack memory 
(USTACK) to specify the address of the NEXT normal uword to be used 
when returning from the utrap routine. The UPCSV is clocked at CPT 
and therefore holds the UPC of the current executable ulnstr. During 
utrap sequences the current executable ulnstr is NO-OP'd while the 
ustack push is done. 

The ustack pointer (USP) address is decremented prior to writing the 
information onto the ustack. 

When in a utrap cycle a signal for clearing utraps is sent to the CEH 
module at CPT 75 to acknowledge a utrap cycle (uword no-op to set up 
the utrap vector address) being in progress. 



2.4 CONTROL STORE PARITY ERROR MICRO TRAP MODE 

This utrap differs from the other utraps in that the clocking of the 
UPCSV is inhibited at CPT . The UPCSV contents which are pushed 
onto the ustack are the address of the control store uword which 
failed parity checking instead of the updated address as in any other 
utrap. 
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UTRAP FLOW 
I 
I 
I 
I 
V 
***************** 

* * 

* UINSTR A *< UTRAP DETECTED 

* * 
***************** 

I I UTRAP FLOW 

> 



NORMAL >I 



***************** 

* * 

* UINSTR B *< 

* * 

***************** 

I 
I 
I 
I 
I 
V 



***************** 

♦NO-OP UWORD TO * 

♦SPECIAL FIELDS ♦ 

* * 

***************** 

I 

I 
***************** 

* * 

* (X) UINSTR ♦ 

* * 
***************** 

I 

I 

I 
***************** 

* * 

* (X+N) UINSTR ♦ 

* * 

***************** 

I 

I 
***************** 

* * 

* RETURN UINSTR ♦ 

* * 
***************** 

I 



NO-OP FOR (1) UWORD, 
SET VECTOR FOR NEXT 
UWORD. VECTOR ADDRESS 
=0100 THRU 010F f OR 
1100 — 110F. PUSH 
UPC SV TO USTACK 
(ADDRESS OF UINSTR B) . 



START OF UTRAP HANDLER 
ROUTINE. BEN + J FIELDS 
DETERMINE NEXT UWORD 
ADDRESS. 



USES USTACK FOR NEXT 
UINSTR ADDRESS (UINSTR 
B) . J FIELD AND BEN 
SHOULD BE CLEAR. ECO 
TO DISPATCH THE 
RETURN IN 
CERTAIN CASES 



Figure 2-2 
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2.5 CACHE STALLS 

Cache Stalls are basically due to the Cache data not present during 
reads, and the Cache waiting on I/O subsystems during writes. 

For a complete definition of conditions causing a Cache stall refer to 
the Cache Subsystem Specification. During Cache Stalls other uword 
functions are temporarily put in a NO-OP state by sending out the 
clear uword signal to other subsystem units. This NO-OP condition may 
last for several Micro cycles until Cache is finished and negates the 
stall signal. 



Upon completion of Cache Stall the next ulnstr to be performed would 
be the ulnstr that would have been executed if the stall had not 
occured. 

The UPCSV contents are selected thru the UMX to be the UPC to be used 
to address the uword when the stall signal is asserted and when the 
stall signal becomes false. 

STALL FLOW 



I 
I 

V 
***************** 

* * 

* UINSTR A * 

* * 
***************** 

I I 

I 

I 



SPECIAL FIELDS ARE HELD OR CLEARED 
UNTIL STALL IS FINISHED. UPCSV 
MAINTAINS THE ADDRESS OF B, WHICH 
WILL BE ENTERED UPON THE FINISH 
OF STALL. 



STALL DETECTED 



NORMAL >I 

I 
I 



***************** 

* * 

* NO-OP UINSTR *< — 

* * 
***************** 

I 

I 

V 
***************** ***************** 

* * YES * *N0 

* UINSTR B *< * STALL FINISHED? *-- 

* * * * 
***************** *********************** 

I 
I 
I 
I 
V 



Figure 2-3 
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2.6 SYSTEM INITIALIZE 

During Init the following conditions are held: 

o All USC registers are held clear except the UECO UPCSV, UPC 
BREAK, and the V-Bus registers. 

o The UMX selects are held so that a constant utrap vector is 
the UPC address and the decision point branch is inhibited. 

o The Init state is held for one Micro cycle after the system 
Init level goes way to ensure all CPU subsystems start 
operations synchronously. 

o For all conditions that generate initialize refer to the CEH 
and ICL modules specification. 



INIT 



I 

K 

I 

V 

***************** 

* SYSTEM * 

* INIT. * 

* UINSTR * 
***************** 

I 

I 
***************** 

* *YES 

* DCLO? *— 
* * 

*********************** 

I NO 

I 
***************** 

* UINSTR * 

* A * 

* START UP * 
***************** 

I 
I 
I 
I 
I 
V 



THIS FORCES THE INIT. LOOP 
UNTIL POWER BECOMES OK. 

WHEN POWER BECOMES OK, THE 
J FIELD OR BEN FIELD OF THE 
UINSTR AT VECTOR LOCATION 
X10X WILL GENERATE THE NEXT 
UINSTR ADDRESS FOR START UP. 



Figure 2-4 
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2.7 MICRO SUBROUTINE FIELD (USUB) 

The uSub field is a two bit field and the operations are: 
CODE FUNCTION OPERATION 



00 NO-OP No effect 

01 Call USP Decrements 

uStack Word written 

with UPCSV Data 

uPC< (JField orBen) 

10 Return uStack word 

UPC< (JField or Ben) 

or{uStack return 
address-13 bits) 
USP Increments 

11 Decision Point F.P.A to control UPC <12> 
Branch (DPB) JField to control UPC <11:08> 

I Buff to control UPC <07:00> 

Control store bus bits <65:64> make the uSub Field. 



2.8 JUMP FIELD (JFIELD OR UJMP) 



Jump Field <12:00> 13 bits forms the base address for the next Micro 
address. (NUA) Control store bus bits <12:00> make the Jfield. 



2.9 BRANCH ENABLE FIELD (UBEN) 

UBen is a 5 bit field and the type of branches enabled are: 
FUNCTION OPERATION 



Ben 00 No Operation 

Ben 0F-01 1 of 15- (8) way Branch conditions 

Ben 1B-10 1 of 12- (16) way Branch conditions 

Ben 1F-1C 1 of 4- (32) way Branch conditions 



Control store bus bits <76:72> make the uBen Field. 
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2.10 OTHER FIELDS - UBS+UBCT (NOT ON USC) 

(See ID Bus specification) 

FUNCTION OPERATION 



Push uStack USP Decrements 

ID Bus Data Bits <15:00> written 
Uses : 

1. Pass Parameters from 
D register to 

a subroutine 

2. Put a return 
address on uStack 
for console control 

Pop uStack ID Bus (uStack word) 

USP Increments 
Uses: 

1. Adjust uStack 

2. Read the stored 
UPCSV to 
determine 

error locations 



2.11 CALL SUBR OUTINE 

If the ulnstr specifies a call subroutine function the UPCSV is pushed 
onto the uStack and forms the return address to be used later. The 
Ben, JField, and/or Decision point branch then determine the start of 
the subroutine UPC. 

The Micro stack pointer (USP) is decremented prior to the push. 



2.12 RETURN SUBROUTINE 

The push of the call subroutine puts the UPC of the ulnstr that has 
the CALL onto the uStack. When a return function is specified the 
uStack is "OR" D with the J field and/or Ben field of the return 
ulnstr to make t return to the correct next ulnstr past the call 
ulnstr. After the return address is popped off the uStack, the USP is 
incremented. 
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CALL SUBROUTINE AND RETURN 

I 

I 

I 

V 
***************** 

* * 

* UINSTR A CALL * 

* * 

***************** 

I I 



NORMAL- 



I 
•>I 



***************** 

* * 

* UINSTR B 

* 

***************** 



UPCSV PUSHES THE ADDRESS 
OF UINSTR A ONTO THE USTACK. 
BEN, J FIELD OR OPCODE 
SPECIFIER THEN DETERMINES 
THE START OF THE SUBROUTINE 
UPC. 



V 



***************** 

* (X) UINSTR * 

* START * 

* SUBROUTINE * 
***************** 

I 
*< ! 

* T ***************** 

* * 

* (X+N) UINSTR * 

* * 

***************** 

I 

I 
***************** 

* * 

* RETURN UINSTR * 

* * 
***************** 

I 
I 



USTACK USED FOR RETURN ADDRESS. 
J FIELD 'OR' D WITH USTACK DATA 
TO MAKE THE CORRECT RETURN TO 
UINSTR B. 



Figure 2-5 



2.13 POWER UP OR DOWN 

These conditions force the initialize signal which keeps the USC in an 
initialize state until after power becomes good. A constant uTrap 
vector is put onto the UPC lines during bad power. 
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2.14 CONSOLE CONTROLLED OPERATIONS 

The following registers can be accessed by the console: 

The uStack can be written from the ID Bus by a push function. This 
causes the USP to decrement and then write the ID Bus data onto the 
uStack. 

The uStack can be read from the ID Bus by a POP function. The uStack 
data is given to the ID Bus and then the USP is incremented. 

Maintenance return can select the uStack as a source for the NUA. 
This causes the NUA to get the uStack and then the uSP is incremented. 
The console signal to generate maintenance return is 
CIBN D MA INT RTN L. 

The uPC break register can be written from or read by the ID Bus. 

The WCS address register can be written from or read by the ID Bus. 

The WCS Data can be written from the ID Bus in 32 data bit groups. 
When the WCS Data is read by the ID Bus, bits <07:00> reflect the 
eight possible WCS IK address assignments and the presence of the WCS 
control store modules. All zeroes will be read back on ID Bus bits 
<31:08>. 

The uPCSV register, the branch input lines and many other USC signals 
can be read by the V-Bus to the console. 

The Break match signal goes to the clock control and will enable the 
CP clock to be stopped during CPTO of a desired Micro word address if 
the console enable bit is set which also goes to the clock control. 

The Break match signal becomes true when the UPC break register 
contents equals the uPC address of the NEXT uword to be used. This 
signal also is gated to the backpanel during CPT 150 time for an 
oscilloscope sync and to TP1 by the module handle. 

The console can direct any uTrap handling to WCS instead of the normal 
Prom CS by forcing uPC <12> to a % 0NE' during uTraps. This is done by 
the signal CIBN UPC 12(1) H. 

The console can direct a micro word no-op cycle by the signal 
CIBN ROM NOPL. This forces the CLR uword and abort cycle signals to 
be true. 

The timing of ID Bus read/writes of USC registers is done in 
accordance with the ID Bus spec. 

The size of the registers accessed under ID bus operations are: 

uStack = 16 Bits 

'JPC Break = 13 Bits 

WCS address = 16 Bits 

WCS Data = 32 Bits Write, 8Bits read 
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uSC ID Bus address assignments are in Hex as follows 
ADDRESS REGISTER 



20 


Micro stack 


21 


uPC Break 


22 


WCS address 


23 


WCS Data 



When writing or reading the uSC registers by way of the ID Bus, the 
LEAST significant bits will be used to pass the data. 

WCS address register format 



15 



14 



13 12 



00 



PAR 
INV 



MODULO I 
3 CNTR I 



ADDRESS 



<15> = = NORmal Parity 

1 = Inverted Parity 

<14:13> = 00 = WCS Data Bits <31:00> 
01 ■ <63:32> 

10 = <95:32> 

11 = No Group Selected 
<12:00> = WCS address 

The modulo-3 counter will count as follows in binary: 



00 
01 
10- 

00- 

11 



COUNTER OVERFLOW AND ADDRESS INCREMENT 



can only be loaded (INVALID) 



The count of (11) can only be loaded and when loaded no further WCS 
data writes or address increments can take place until the modulo-3 
counter and entire register are reloaded with a valid count. 
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Overflow from the Modulo-3 counter occurs when the count goes from 
(10) to (00) and increment the binary address in bits <12:00>. 

The Modulo-3 counter increments after each WCS write. This allows the 
data to be written in successive higher order 32 bit groups without 
having to perform a WCS address write each time before writing data. 

To write WCS, the WCS address register must be loaded and then a WCS 
write data must be performed. These cycles may be either back to back 
or spaced in time. 

Microstack output data is clocked into a register at CPT and held 
until the next CPTO. 

V-Bus operation allows certain signals on the Micro sequencer to be 
read by the console in a transparent mode in respect to the micro 
sequencer . 

The ID Bus address and read/write decoding are in accordance with the 
ID Bus specification. 



2.15 PICO SEQUENCER AND PRIORITY DECODING 

The Pico sequencer consists of flip-flops clocked at CPTO to hold the 
conditions as exist at the beginning of a micro cycle. The conditions 
held are: 

Initialize 
Maintenance return 
Cache Stall 
Micro Trap 
UECO 

Priority of levels is as follows: 

Highest Priority Initialize 

Maintenance Return 

Cache Stall 

Micro Trap 

uECO 
Lowest Priority Normal 

When maintenance return is true from the console, the CPU clock must 
be stopped and under control of the console. Maint. return keeps the 
NUA lines as the selected source of the UPC lines. 

Maintenance return also inhibits writing of the ustack if a utrap or 
push operation occurs during the maint. utrap. 
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2.16 UPC ADDRESS LATCHING 

The UPC latches hold the UPC lines stable to ensure that the control 
store bus lines are not changing. This is to prevent a false uword 
parity error. Control of the USC UMX tri-stating and decision point 
branch UMX tri-stating and UPC latching keeps the UPC valid. 

At CPT 50 plus gate delays the USC UMX or decision point branch UMX 
are tri-state enabled. The UPC lines <09:00> are valid at CPT 90 plus 
10ns of clock skew to the control store address inputs. The UPC lines 
<12:10> are valid at CPT 94 + 10ns of clock skew at the control store 
chip enable inputs. The inverter and open collector nand gate latches 
are enabled at CPT 125. At CPT 150 time plus gate delays the UMX 
tri-states are disabled with the latches holding the UPC levels. At 
CPT 50 the latches are opened and the next UPC address cycle can 
begin. 

The present address in the UPCSV register will be displayed in 13 leds 
mounted near the module handle. A separate LED by the E-F handle 
section will be used to display the stall condition. 



CHAPTER 3 
INTERNAL DATA BUS SPECIFICATION 



The Internal Data Bus is a high speed data path connection between the 
major functional areas of the CPU. It has four purposes: 

1. Allows data to be transferred to/from the internal status and 
control registers and translation buffer. 

2. Allows data in the form of displacements, and short & long 
literals to be transferred from the Instruction Buffer to the 
CPU and ACC data paths. 

3. Allows data transfers between memory (via the D register) and 
the ACC data paths to take place. 

4. Allows access of the internal registers from the console 
under console control in a maintenance operation mode. 



3.1 FUNCTIONAL OPERATION 

The ID BUS control is derived from a control field in the UWORD in 
normal operation and from the console interface logic in maintenance 
operation . 



3.1.1 Normal Operation 

Data transfers over the ID BUS are always directed to the Q and from 
the D register in the CPU data paths. The ACC will, however, snapshot 
the data on the bus when a transfer is being made from the IBUF to the 
Q register. 
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3.1.1.1 ID 
field to 
source or 



BUS 



Addresses - The ID BUS signal lines contain a six bit 
specify which internal register has been designated as the 
destination of data on the bus. 



The address assignments are as follows 



00 


IBUF DATA 


20 


USTACK 


01 


TIME OF DAY 


21 


UBREAK 


02 


NOT USED 


22 


WCS ADDRESS 


03 


SYSTEM ID 


23 


WCS DATA/STATUS 


04 


CNSL RXCS 


24 


POBR 


05 


CNSL RXDB (TO ID) 


25 


P1BR 


06 


CNSL TXCS 


26 


SBR 


07 


CNSL TXDB (FROM ID) 


27 


RSVD FOR SYS SPACE 


08 


DQ (ID MAINT ONLY) 


28 


KSP 


09 


NEXT INTERVAL REG. 


29 


ESP 


0A 


CLOCK CS 


2A 


SSP 


0B 


INTERVAL COUNTER 


2B 


USP 


OC 


CES 


2C 


ISP 


0D 


VECT 


2D 


FPDA 


0E 


SIR 


2E 


D.SV 


OF 


PSL 


2F 


Q.SV 


10 


TBUF DATA 


30 


TO 


11 


-RSVD- 


31 


Tl 


12 


TBUF REG0 


32 


T2 


13 


TBUF REG1 


33 


T3 


14 


ACC REGO 


34 


T4 


15 


ACC REG1 


35 


T5 


16 


ACC MAINT REG. 


36 


T6 


17 


ACC CONTROL/STATUS 


37 


T7 


18 


SBI SILO 


38 


T8 


19 


SB I ERR REG 


39 


T9 


1A 


SBI TIMEOUT ADDRESS 


3A 


PCBB 


IB 


SBI FAULT/STATUS 


3B 


SCBB 


1C 


SBI SILO COMPARATOR 


3C 


POLR 


ID 


MAINTENANCE 


3D 


P1LR 


IE 


CACHE PARITY 


3E 


SLR 


IF 


-RSVD- 


3F 


RSVD FOR SYS SPACE 
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3.1.1.2 ID BUS Directional Control - One of the signal lines on the 
ID BUS will specify whether an internal register is to be read onto 
the bus or if data is to be clocked from the bus into the internal 
register. The D register in the Data Paths always acts as the source 
and the Q register as the destination. 

ID WRITE L 



H - ID BUS DATA< — (ADDRESSED REG.) 
L - (ADDRESSES REG . ) <— ID BUS DATA 



3.1.1.3 ID BUS Data - There are 32 data signals on the ID BUS. 



3.1.1.4 Signal Summary - There are 39 signals on the ID BUS; 



NO. OF LINES 



SIGNAL NAME 



32 
6 



BUS ID D[31:00] L 

ID LEFT ADDR (5:0) H 
or ID RIGHT ADDR (5:0) H 

ID LEFT WRITE L 
or ID RIGHT WRITE L 



3.1.1.5 ID 
in the UWORD. 
therefore 



BU S Control - The ID BUS signals are controlled by a field 

The same UWORD field also controls MD BUS operation and 

requires a 1-bit field in the UWORD for BUS control 



definition. 



It 
is, 



is important to understand that the ID BUS is always active. That 
when the BUS control field defines MD BUS operations the ID 
address and write signals are zero and thus controlling the IBUF DATA 
to be gated onto the ID BUS data lines. The UQK field of the UWORD 
will select the appropriate time to clock the ID BUS data into the Q 
reg ister . 
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The UWORD fields which control 10 and MD BUS operations are as 
follows. 

I UFS | UMCT [3:0] I 
| | 1 

I I X I UCID [2:0] | 

UFS - UWORD Function Select, 1 bit 

- UMCT [3:0] = MD BUS CONTROL; ID BUS < — IBUF DATA 

1 - UCID [2:0] = ID BUS CONTROL & Console Control 

No MD BUS function selected by micro instruction. 
UMCT - UWORD Memory Control Field, 4 bits 

UFS=0: SEE CACHE-SB I-TB SUBSYSTEM SPEC. 

UFS=1: UCID - UWORD Console and ID bus control field 

4 - ID DATA <— (Internal Reg [SC 5:0]) 

5 - ID DATA <— (Internal Reg [UKMX 5:0]) 

6 - (Internal Reg [SC 5:0]) < — ID DATA 

7 - (Internal Reg [UKMX 5:0]) < — ID DATA 

Internal Register addresses are generated either from the SC data path 
register or from the UKMX field of the micro-instruction. 

& Console Control: 

- NO-OP 

1 - UNUSED SEE UWORD SPEC. 

2 - CNSL ACK 

3 - CNSL CONT 



3.1.2 Maintenance Operation 

The ID BUS may also be controlled from the console interface logic in 
a maintenance mode operation. This allows access to writable control 
store, the USTACK, and visibility of internal registers from the 
console without the need of main microcode running. In maintenance 
mode operation only, the Data Paths D & Q registers may be addressed 
as an internal register over the ID BUS. 



3.1.2.1 Cons ole Contr ol of ID BUS - Control of the ID BUS is g 

accompl ished via an interface signal generated by the console ^ 

interface logic, ID MAINT. W 

50 

When this signal indicates a maintenance operation the console will > 

assert ID BUS address and write signals and may assert data. f 

•-3 

> 



3.2 ID BUS REGISTER DESCRIPTION 



3.2.1 IBUF DATA 



DATA (31: 00) | 

I 



-READ/WRITE REGISTER- 
SEE CONSOLE SPEC 



DO 

G 

en 



31 oo co 

m 

I o 



M 

.___ ,__„_ . „__ ___„ ._ n 

> 

-READ ONLY REGISTER- J^ 

SEE IBUF SPEC O 

Z 



3.2.2 SYSTEM ID 

31 00 

I I 

I ID(31:00) | 



-READ ONLY REGISTER- 
SEE CONSOLE SPEC 



3.2.3 CNSL RXCS 
31 08 07 06 05 00 

I I I I I >0 

I 0< >0 | D0NE | RIE | 0< >0 | o, 

I I i I I -J 



I 

en 



3.2.4 CNSL RXDB 
31 00 



Z 

DATA(31:00) I g 

i > 



-READ ONLY REGISTER- 3 

SEE CONSOLE SPEC H 

OS 

c 
en 

3.2.5 CNSL TXCS CO 
ng 

31 08 07 06 05 00 ™ 



I 



*d 



I < >0 I RDY I TIE |0< >0| o 

I III I > 



O 

-READ/WRITE REGISTER- z 

SEE CONSOLE SPEC 



3.2.6 CNSL TXDB 
31 00 

| DATA (31: 00) I 

I I 



-WRITE ONLY REGISTER- 
SEE CONSOLE SPEC 



3.2.7 CLOCK CONTROL/STATUS 

31 16 15 14 08 07 06 05 04 03 01 00 ^ 

_ _ _ _ -- - | | | | * 

| III INTR I CLK I SGL I I II 

| < >0 IERR |0< — >0 I REQ I IE I CLK I XFER |0< >0 I RUN I W 

III II <k 



-READ/WRITE REGISTER- w 

SEE INTERVAL TIME CLOCK SPEC _* 

in 

50 

Z 

3.2.8 NEXT INTERVAL COUNT r 

31 00 ^ 

: _3 

I I > 

I COUNT(31:00) | ro 

1 _________ _ ' s 



en 

-WRITE ONLY- JJ 

SEE INTERVAL TIME CLOCK SPEC ™ 

M 
*} 
M 
O 

> 

3.2.9 INTERVAL COUNT |jj 

O 

31 00 Z 



COUNT(31:00) I 

I 



-READ ONLY REGISTER- 
SEE INTERVAL TIME CLOCK SPEC 



3.2.10 TIME OF DAY 
31 00 

I I 

I TIME(31:00) I 



-READ/WRITE REGISTER- 
SEE TIME OF DAY SPEC 



I 



ro 

Ul 

I 

•J 



3.2.11 ACC REG #0 THRU »1 

31 00 =| 

W 

r 



I I 

I DATA (3 1:00) I 

I I 



3 

SEE ACCELERATOR SPEC ^ 

> 



3.2.12 ACC MAINT 



DO 

G 
W 



31 30 16 15 14 00 «o 

ra 

II II I M 

I | I LOAD I I *9 
| I ACC UPC I UBKl ACC TRAP UPC I S 

II II I > 

H 



O 
-READ/WRITE REGISTER — SEE ACCELERATOR SPEC 25 



3.2.13 ACC CONTROL/STATUS 

31 30 27 26 25 07 06 04 03 00 

II II III 

I I I ACC I I REV I ACC I 

I ERR I ERROR STATUS I EN I 0< >0 I LVL I TYPE I 

II II III 

-READ/WRITE REGISTER — SEE ACCELERATOR SPEC 

3.2.14 TBUF DATA 

31 00 

_ - ^ 

| DATA (31: 00) I & 

I I 



(0 



-WRITE ONLY — SEE CACHE SUBSYSTEM SPEC 



I 
CD 



3.2.15 TBUF REGO 
31 21 20 



19 



18 17 



16 15 



08 07 



06 



05 



04 



01 



00 



I I REPL | FORCE I FORCE | LAST I TB | TB I 

I 0< — >0 I BOTH I REPL I MISS I REF | Gl | GO | 
I I I I I I HIT | HIT I 



I FORCE I 

I TB PE I MME 

I I 



-READ/WRITE REGISTER- 
SEE CACHE SUBSYSTEM SPEC 



3.2.16 TBUF REG1 
31 21 20 



08 07 06 05 04 



00 



I I I I I I I 

I I TBUF | | LAST I | TBUF I 

I 0< >0 I PARITY ERR 1 I WP | | IPA STATUS I 

I I I I I I I 



Z 

w 
» 

z 
> 

> 
00 

c 
en 

en 
ns 
w 
n 

t-t 
*I 
M 

o 
> 

•-3 

M 
O 

z 



-READ/WRITE REGISTER- 
SEE CACHE SUBSYSTEM SPEC 



3.2.17 SBI SILO 
31 30 



29 



25 24 



22 21 



18 17 



16 15 



00 



FIRST 
AFTER 
FAULT 



INTLK 



ID(4:0) 



TAG (2:0) 



B(31:28) 

or 

M(3:0) 



CNF(1:0) 



TR(15:00) 



-READ ONLY- 
SEE SBI REGISTER DEFINITION 



T3 

W 

I 



3.2.18 SBI TIMEOUT ADDRESS 
31 30 29 28 27 



MD 
SEL 



I I 

I PROT I 
I CHK I 



PA(29:2) 



-READ ONLY- 
SEE SBI REGISTER DEFINITION 



3.2.19 SBI FA ULT/STATU S 
31 



30 29 



28 27 



26' 



25 



20 19 



PAR 
FLT 



I I I I 

I I I I 

I URD I I MXM I XMIT 

I FLT I I FLT I 

I I I I 

I I I I 



00 



lo< ; 



18 



17 



16 



15 



1 
1 

>0 I FLT 


FLT 


SBI 


FLT 


0< 


I INTR 

1 
1 


IE 


FLT 


SILO 
LOCK 





00 



>o 



z 

-3 

M 
W 

z 

> 
f 

o 
> 

> 

09 

c 
en 

w 

w 
o 

n 

M 

o 

> 

M 
O 

z 



-READ/WRITE REGISTER- 
SEE SBI REGISTER DEFINITION 



3.2.20 SBI SILO COMPARATOR 
31 30 29 28 27 26 23 22 



20 19 16 15 



I I 

SILO I SILO I 

LOCK I LOCK I LOCK 

| IE I UNCOND 

I I 



1 1 
1 1 

I LOCK I 


1 

1 

CMD/ I 


TAG 


COUNT I 


I CODE I 

1 1 


MASK I 

1 




FIELD 1 



0<- 



-READ/WRITE REGISTER- 
SEE SBI REGISTER DEFINITION 



00 



->0 



0) 
(0 

U) 

I 



3.2.21 SB_I M AINTENANCE 
31 28 27 



23 22 



21 



20 17 16 15 14 13 12 



11 



10 09 08 



07 



00 



FORCE SB I 
FAULT 



MA I NT 
ID (4:0) 



FORCE 

SBI 
INVAL 



EN 
SBI 
INVAL 



REV 

CACHE 

PAR 



FORCE 
MISS 



I 

I DIS 

FORCE | SBI 

REPL I CYC 



REV 
PI 



MATCH 



FORCE 
TO 



|0<- 



->0 



-READ/WRITE REGISTER- 
SEE SBI REGISTER DEFINITION 



3.2.22 SBI CACHE PARITY 
31 16 15 



14 



13 



00 



0<- 



•>0 



CACHE 
PAR 
ERR 



CP 
ERR 



PARITY 
OK 



-READ ONLY- 
SEE SBI REGISTER DEFINITION 



3.2.23 US TACK 

31 



16 15 



00 



Z 
H 
W 
73 
2 
> 

> 
03 

c 

Ui 
Ui 

m 
o 

M 
*1 
M 

o 

> 

•-9 

M 
O 

z 



0<- 



■>0 I 



DATA (15: 00) 



-READ/WRITE REGISTER- 
SEE MICRO SEQUENCER SPEC 



13 
(0 



U) 



3.2.24 UBREAK 
31 



I 0<- 



13 12 

I 



00 



•>0 



I 



DATA(12:00) 



-READ/WRITE REGISTER- 
SEE MICRO SEQUENCER SPEC 



3.2.25 WCS ADDRESS 

31 16 15 14 13 12 00 

I III ~\ 

I I INV | DATA | | 

| < __ >0 | cs | SLICE | wcs ADDR (12:00) I 

I I PAR | SEL | | 

-READ/WRITE REGISTER- 
SEE MICRO SEQUENCER SPEC 



Z 

» 

as 
> 
f 

a 

> 

> 

c 
en 

en 

w 
n 

M 

T« 

M 

o 

> 

M 

o 

z 



3.2.26 WCS DATA/STATUS 

31_ _ _ 00 

^ . _ _ _____ _ 

I WCS DATA (31: 00) | 

I _____ _ _ ' 

-WRITE ONLY BITS- 

31 08 07 00 

^ ____ _ _ 

| o< >0 I WCS IK BANK | 

I I AVAILABILITY | 

[ _ I I 

-READ ONLY BITS 
SEE MICRO SEQUENCER SPEC 



0* 
vd 
0) 

W 
I 

(-• 
to 



3.2.27 D,Q (MAINT MODE ONLY ) M 

31 00 g 

! i > 

I DATA TO Q REG. (31:00) | !-. 

H 

-WRITE ONLY BITS- > 

,. OB 

31 00 C 



J I CO 

I D REG(31:00) | 13 

i i 8 



> 

1-1 

o 

z 



-READ ONLY BITS- 

3.2.28 SIR 

31 21 20 16 15 01 00 

^ ^ ^ _______ _ _ 

I 0< >0 I IPLA I SIR(0F:01) | | 

I 1 ' ' _ _ I' 

-READ/WRITE REGISTER- 
SEE INTERRUPTS $ EXCEPTIONS SPEC 

3.2.29 PSL 

31 30 29 28 27 26 25 24 23 22 21 20 16 15 08 07 06 05 04 03 02 01 00 

I III II I II I I I I I I I I I I 
I III II CUR I PREV II | I I I I I I I I I 
I CMP | TP I 00 | FPD | IS | MOD | MOD | | IPL |0< — >0 I DV | FU I IV | T | N | Z | V I C I 

I III II I II I I I I I I I I I I 

<tj 

iQ 

-READ/WRITE REGISTER- <1> 

U) 

I 

»-< 



3.2.30 CPU ERROR/STATUS 
31 



17 16 



15 14 12 11 07 06 04 03 02 00 



1 NESTED 


CS 


CS PAR 










1 ERR 


PE 
SUM 


STATUS 


UB RANCH 
CCC 


ARITH 
TRAP 
CODE 


PME 


ASTLVL 1 



FIELD 



ASTLVL 

(Asynchronous System 
Trap LeVeL) 



PME 

(Performance Monitor 

Enable) 



ARITH TRAP CODE 
(ARITHmetic TRAP 
CODE) 



DESCRIPTION 



Loaded or read by micro-code 
in MTPR Src, @#ASTR or 
MFPR @#ASTR, dst. Used in 
execution of REI instruction 
for AST delivery. Read/Write. 
Cleared on power up. 

Loaded or read by micro-code 
in MTPR Src, §#PMR or MFPR 
@#PMR, dst. Cleared on power 
up. Read/Write. 



Loaded by ha 
integer over 
the V bit i 
CCL7 funct 
field of the 
loaded by 

arithmetic t 
other means 
ARITHMETIC 
Read/Write, 
up. 



rdware for enabled 

flow traps when 

s set using the 

ion of the UCCK 

UWORD. Must be 

microcode for 

raps detected by 

If non-zero an 

TRAP occurs. 

Cleared on power 



NOTE: The write is disabled 
if the appropriate Trap enable 
in PSL is for the code being 
loaded . 



The codes have 
meaning : 



the following 



- NO ARITHMETIC TRAP PENDING 

1 - INTEGER OVERFLOW 

2 - INTEGER DIV by ZERO 

3 - FLOATING OVERFLOW 

4 - FLOATING DIV by ZERO 

5 - FLOATING UNDERFLOW 

6 - DECIMAL OVERFLOW 

7 - DECIMAL DIV by ZERO 



Z 
H 
W 
50 

Z 

> 

XT 

•-3 
> 

CP 

C 
CO 

en 
►o 
w 
o 

M 
*J 
M 

n 

> 

•-3 

H 

o 
z 



0) 

<t> 

I 



UBRANCH CC 
(Micro BRANCH 
Condition Codes) 



Loaded by the micro-code or 
by the CCL1 function of the 



CS PE(2:0) 

(Control Store Parity 

Error) 



CS PE SUM 

(Control Store Parity 

Error SUMmary) 

NESTED 
ERR 



of the UWORD. 
Cleared on power 



UCCK field 
Read/Write, 
up. 

BIT 



7 - ALUC 

8 - ALUZ 

9 - ALUN 

10 - EALUZ 

11 - EALUN 

Status indicators for Control 
Store Parity errors as 
follows : 

CS PEO - CS DATA(31:00) 
CS PE1 - CS DATA (6 3: 32) 
CS PE2 - CS DATA(95:64) 

Cleared on power up or by 
writing a one into CS PE SUM 
bit position. Read Only. 

The 'or' of CS PE(2:0) 
Read/Write. 



Read/only bit used by 
micro-code in memory 

management flows. Cleared on 
power up. 



z 

M 
50 

Z 
> 

r 

> 

03 

C 
Ui 

Ui 
13 

KJ 

n 

M 
*1 

Ht 

o 
> 

H 

o 

z 



3.2.31 VECTOR 

31 26 25 24 21 20 16 15 09 08 00 

I I I I I " "I | 

I I PRIOR I | NUMB | | | 

I 0< >0 I VALID I PRIOR I ONES I 0< >0 I VECTOR | 

!______ i i i i i i 

-READ/WRITE REGISTER- 
SEE INTERRUPTS & EXCEPTIONS SPEC 



T3 
I 

M 

Ln 



3.2.32 FPDA, D.SV, Q.SV m 

•- 1 — s 2 

31 00 m 

so 

J 



I I 

I DATA(31:00) | 



I I 5 

Hi 

> 

DESCRIPTION CD 

C 

CO 

Read/write registers used by micro-code in memory co 

w 
O 



management flows. 2 



TO thru T9 

31 00 2 



I I > 

I DATA (3 1:00) | 2 

I I O 
z 



DESCRIPTION 



Read/write registers used by micro-code as temporary 
holding registers. 



3.2.33 POBR P1BR SBR POLR P1LR SLR PCBB SCBB KSP ESP SSP OSP ISP 
31 00 



| DATA(31:00) I 

I I 



-Read/Write System registers- 



no 
a> 

a> 

u> 
l 

(-• 
c^ 



CHAPTER 4 
INSTRUCTION BUFFER 



The instruction buffer is a eight byte array that fetches and decodes 
instruction stream data to decode opcodes and operand address 
information. It is basically made of a fifo type byte buffer with 
decode logic to generate micro addresses and branch conditions. 

The major sections of the instruction buffer are: 

1. Buffer Data Path 

2. I-Stream Data Mux 

3. IR Decode Logic 

4.1 BUFFER DATA PATH 

The instruction buffer data path consists of four major components: 

1. A buffer register for storage of information. 

2. A multiplexer shift network for advancing data thru the 
buffer register. 

3. An input multiplexer for selecting data from memory or from 
the shift network. 

4. A byte rotator used to convert the long word aligned data 
from the cache into byte addresses positions. 



4 «1«1 Buffer Register 

This register is divided into eight sections of nine bits each. The 
nine bit sections contain: 
8 Bits of data 

1 Bit to indicate valid data 
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The bytes within the register are designated as bytes 7 thru 0. Byte 
corresponds to data with the lowest value memory addresses. 
Likewise, the memory address increases with higher number byte 
positions . 



Most Sig 
Mem Adrs 



Least Sig. 
Mem Adrs 



I 



I I 
I I 

7 6 



I I 
5 4 3 



Byte Position 



The chip types for this register are 74S174's for bytes 7 thru 2. For 
bytes 1,0 will be 74S175's. 

The entire register will be clocked at CPU TO with no gating 
conditions. 



4. 2 SHIFT NETWORK 

4.2.1 Multiplexer Shift Network 



The shifting scheme for the instruction 
multiplexer that is arranged to shift nine 
4 positions right at each micro cycle. The 
will be from a decode of 4 bits of the 
are : 



buffer is a four input 

bit sections by 0, 1, 2 or 

control of the shifter 

micro word. The micro controls 



UIBC 

- NOP 

1 - STOP 

2 - FLUSH AND LD VIBA 

3 - START 

4 - CLR BYTES 0,1 

5 - CLR BYTES 2,3 

6 - NOT USED 

7 - B DEST 

8 - NOT USED 

9 - NOT USED 
A - NOT USED 
B - NOT USED 

C - CLR BYTE 

D - CLR BYTE 1 

E - CLR BYTES 0,1,2,3 

F - CLR BYTES 1-5 CONDITIONAL 
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4.2.1.1 MICRO Control Use - 

- NOP -r Default State. Has no effect on the instruction 

buffer. 

1 - STOP - The assertion of this code will disable the 

instruction buffer cache requests. Current use is for micro 
code fault routines. 

2 - FLUSH - This code is used to clear all valid bits of the IB. 

This will be used for jumps or branches and other conditions 
that change the PC. The same micro STATE will load the 
virtural IBA. 

3 - START - The assertion of this code will resume prefetch 

operations to the cache. 

4 - CLR 0,1 - This is used for compatibility mode to advance to 

the next OP code. It is also used in VAX mode for optimized 
fast execute (S , R or R f R) or 16 bit branch destinations. 

5 - CLR 2,3 - This is used only in compatibility mode for 

discarding 16 bit displacements and literals after they have 
been used. 

7 - B DEST - This code is used by the microcode to extract branch 
destinations from the instruction stream. 

C - CLR - This is used in VAX mode to advance to the next 
opcode . 

D - CLR 1 - This is used in VAX mode for discarding the specifier 
from the IB. It is only used for displacement mode 
addressing, absolute addressing or long literals. In these 
modes, the last thing removed from the instruction buffer is 
the specifier. In all other modes, the specifier will be 
removed by hardware. 

E - CLR 0,1,2,3 - This is used in compatibility mode for 
optimizing literal to register instructions. 

F - CLR 1-5 Conditional - This is used in VAX mode for discarding 
long literals or displacements from the IB. The hardware 
will decode the specifier and/or opcode to determine 8,16, or 
32 bits of data. In the modes that do not have I-stream data 
other than the specifier, the specifier itself will be 
discarded. This code is used at all FORK entries. 
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4.3 INPUT MULTIPLEXER 

The input MUX is used to determine if data is to be loaded from the 
shift multiplexer or the cache data. The select of this MUX is 
controlled individually for each 9 bit section. It is selected for 
the shifter if the 9 bit section being shifted in is val d. Otherwise 
it is selected for cache data. 

4.4 BYTE ROTATOR 

This hardware is located as one of the sources to the input MUX. It 
is controlled by the IB by the low order two bits of the IB address 
register. These two bits will rotate the long word data such that the 
byte address will specify which byte is in the low order 8 bits. 

IBA Byte Positions 



I I I 
00 | 3 I 2 I 

I I I 



I I I I I 
01 | I 3 I 2 I 1 I 

I I I I I 



I I I I 
10 I 1 I I 3 I 2 

I I I I 



I I I I I 
11 I 2 I 1 I | 3 I 
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4.5 I -STREAM DATA MUX 

One of the functions of the instruction buffer is to sort out 
displacements, literals and other information and present it to the 
CPU data path. The IB will do as much as possible to make the data be 
in a useable form. This implies sign extension and shifting where 
necessary. To do this requires a decode of the mode, specifier, 
context lookup and opcode. 

For compatibility mode, the IDMX will be selected for either bytes 3 
and 2 or byte shifted for branch displacements. 

1. ID BUS B3,B2 

I I I I I (SXT ON B3-7) 



I II I 

16 Bit Displacement 16 Bit Instruction 
16 Bit Literal 



2. ID BUS BO 

I I I I (SXT ON BO-7) 



I III 

V — V— 

BR 8 BIT 

OPCODE BRANCH DISPLACEMENT 

The branch displacement will be left shifted by one and sign extended 
on bit 7. For VAX Mode The IDMX Will Be As Follows: 

Mode Data Comment 






S# 


1 


s# 


2 


S# 


3 


S# 


4 


(E) 


5 


R 


6 


(R) 


7 


-(R) 



7:0 Zero extended 

7:0 Zero extended 

7:0 Zero extended 

7:0 Zero extended 



X 
X 
X 
X 



(R)+ 31:00 1,2, or 4 bytes depending 

on context. 
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§(R) + 



A 


D8 


B 


§ D8 


C 


D16 


D 


@ D16 


E 


D32 


F 


@ D32 



8 Bit BDest 
16 Bit BDest 

Floating Short Literal 



31:00 

7:0 
7:0 
15:00 
15:00 
31:00 
31:00 

7:0 
15:0 



Sign extended. 



Sign extend on bit 7 

Sign extend on bit 7 

Sign extend on bit 15 

Sign extend on bit 15 



Sign extend on bit 7 
Sign extend on bit 15 



31 



ID BUS | 



Zeros 



16 15 14 13 12 11 10 9 8 7 6 5 4 

I 01 II Zeros I I I I I I |Zeros| 



SPECIFIER 



I I 

7 6 5 4|3 210 

! | | EXP | FRA | 



4.6 PC UPDATES 



PC Delta i 
the PC reg 
length of 
This mean 
the PC is 
el iminate 
determine 
be added 
addressing 



s a three bit number that is added 
ister. The PDP-11 architecture ha 
I-stream is fetched, that the PC i 
s that during displacement mode 
pointing at the end of the dis 
an extra micro instruction on th 
the length of I-stream data to be 
to the PC. The end result 
can be done very quickly with the 



to the low order bits of 
s defined that each time a 
s updated to reflect it. 
addressing off of PC, that 
placement. In order to 
is flow, the hardware will 
used and create a value to 
is that displacement mode 

instruction buffer. 



The PC update value will 
of I-stream required, 
are : 

Mode 



reflect the specifier (if any) and the length 
Addressing modes that require additional data 



Length 













8- 


(R) + 


if R=PC 


Context 


Dependent 


9- 


@(R) + 


if R=PC 


4 Bytes 




A- 


D8 




1 Byte 




B- 


@ D8 




1 Byte 




C- 


D16 




2 Bytes 




D- 


@ D16 




2 Bytes 
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E- D32 4 Bytes 

F- @ D32 4 Bytes 

The complete number to be added to PC will include the length number 
for the addressing mode plus one for the specifier. Note that the 
update for the opcode must be handled seperately by micro code. 

Compatibility mode updates will work in a similar manner. The 
hardware will determine if any address calculation is required and the 
mode. If the following I-stream data is required, the number two will 
be added to the PC. If not, a zero will be added. 

If a fault is detected such as error, TB miss or stall, the hardware 
will force the PC update to be zero. 

If the opcode is a single byte instruction, the update number will be 
zero. 

If the decision point entry is to an execute flow, the update number 
will be zero. 

If first part done is set, the PC update will be zero. 



4.7 IR DECODE 

The IR decode will be done by the use of Roms. There are presently 
eight major execution points that are using a hardware generated 
address. The evaluation of additional operands will be done by a 
micro subroutine which is directed by a special subroutine call on the 
specifier. 

Additional information such as context information and register 
addresses are obtained from the IR decode. The register numbers will 
be: 

4 bits SRC Reg from byte 1 (SPl ADR) 
4 bits DST Reg from byte 2 (SP2 ADR) 
4 bits SRC Reg latched from byte 1 (PRN ADR) 

Note that the SRC register number will always be valid and the 
destination register is an assumption of S or R specifier for byte 1 
followed by R specifier for the destination. The register numbers 
will be multiplexed for compatibility mode versus VAX mode. The 
multiplexer will be A 74S158 with (L)=l polarity. The outputs will be 
stable at CPUTO plus 27 N.S. (Clock skew not considered.) 
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4.7.1 Register Latched Number 

The SRC register latched outputs will be clocked at CPU TO during the 
MICRO state that does a execution point entry or a MICRO subroutine 
call to a specifier evaluation. This will physically be done by the 
MICRO control that bumps the specifier from byte 1. 



4.7.1.1 Context Lookup - The context lookup information will also 
come from a Rom. This implies that the context information will not 
become available until CPU TO plus 100 NS from the time the execution 
point, specifier or opcode has been changed. This information will 
define: 

byte 

Word 

Long 

Float 

Double 

Quad 

ASRC 

VSRC 



4.7.1.1.1 Specifier 1 Constant - This constant will be used by MICRO 
code to do register updates for auto increment or auto decrement 
modes. This will be done with 4 lines connected to the fast constants 
multiplexer on the data path boards. The number generated for VAX 
mode will be: 

1 - Byte 

2 - Word 

4 - Long/Float 
8 - Quad/Double 

This will be generated from the context lookup table for each 
execution point entry. 

During compatability mode, this number will be derived from a decode 
of the instruction. This constant is only selected during the 
evaluation of the source operand. All single operand instructions and 
register class instructions use SP2 constants. 

The number generated will either be 1 or 2. A one is generated if it 
is a byte instruction and the register field is not register six or 
seven. A two is generated if it is a word instruction or byte 
instruction with register six or seven. 
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4.7.1.1.2 Specifier 2 Constant - This constant will be used by micro 
code during compatibility mode flows. It is used for auto increment 
or auto decrement address mode updates. The number generated will be 
either one or two. A one is generated if it is a byte instruction and 
the destination register is not register six or seven. A two is 
generate if it is a word instruction with destination register six or 
seven. 

During VAX mode, this number will be zero. 



4.7.1.2 Data Length Field - A three bit field is generated from the 
operand context table to control the UDT, scratch pad control or AMX 
sign extention. The following numbers are generated. 

1-8 bit Data Type (Byte) 
2-16 bit Data Type (Word) 
4-32 bit Data Type (Long, Float, Quad, Double) 

Also generated is a signal that indicates the instruction opcode is 
either floating or double floating type. This will be used to 
determine condition code setting. 



4.8 EXECUTION POINTS 

Execution points are places in the micro flows where the IR decode 
logic directs instruction execution. Execution point entries are of 
two basic forms. The entry point will either evaluate an operand 
specifier, or enter an execution flow unique to the present 
instruction. 

The mechenism for doing a execution point entry is by making the USUB 
field equal to three. In order to make the instruction buffer do the 
proper operation, the UIBC field must be set to F. In order to get 
the PC at the correct valve, the UPCK field must be set to F. The 
UMCT field must be set up to allow IB data to the ID BUS and the Q 
register must be clocked. 

This micro control selection will perform the necessary functions to 
evaluate an operand specifier. The Q register will receive any 
literal, address or displacement data. The PC will be updated to 
point to the beginning of the next specifier or opcode. The 
instruction buffer will advance over the data transferred into the Q 
register. 

If the entry was to an execution flow, the hardware will force the PC 
update to be zero and the instruction buffer to hold. 
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4.9 FIRST PART DONE 

This is a flag that is set by micro code that indicates an interrupt 
was taken during the middle of an instruction. At the completion of 
the interrupt service routine, the instruction is fetched a second 
time. Instead of evaluating specifiers again, the IR decode will 
enter an execution flow. 

This done by setting the execution point count to 7 with First Part 
Done = 1. This implies that interruptable instructions have a maximum 
of 7 execution points. 

In order to get to the next instruction, the micro code must load a 
new address into the IBA and flush the IB. Before doing so, it must 
clear First Part Done. 



4.9.1 IB Addressing 

The address registers for the instruction buffer memory cycles are 
located in the data path and translation buffer. The data path holds 
the virtual address of the IB. The translation buffer has the 
physical address for the IB. 

The virtural address is used for two reasons. First is for error 
reporting. The other use is when a page boundary is crossed. The 
virtural address is used to check the translation buffer for the new 
page. 

The physical address register is loaded from the output of the 
translation buffer. After each reference, the address is incremented. 
If a page boundary is not crossed, the address must still be valid. 
If a page boundary is crossed, the hardware forces a translation to 
occur and the physical address is loaded. 

If the translation fails, the data locations are flagged in the 
instruction buffer. When the code requests this data, a TB fault is 
taken. The code then interperts the cause. 

Both the virtural and physical addresses count by 4 bytes at a time. 
The control of this counting is done by the IB. 
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4.10 CACHE INTERFACE 

The interface to the cache is done with the MD BUS and several control 
signals. 

1. IB request H - Asserted when there is room to put data in the 
instruction buffer and the address registers are not 
counting . 

2. IB READ DATA L - Asserted when data is to be loaded into the 
IB. It is inhibited during flush states. 

3. Count H - Asserted during the micro state following a read 
operation from cache to IB. It is used to count both the 
virtural and physical address register. 

4.11 ACCELERATOR INTERFACE 

The interface to the floating point accelerator is done by tracking 
the IR decode. The instruction opcode and the three bits of execution 
point count are sent to the FPA. The FPA will decode opcodes that it 
wishes to operate on. The execution point count allows it to decide 
when to jam the MICRO program into WCS. The restriction to this 
interface is that the FPA must follow the same combinations of 
specifier evaluations and execution entries as the CPU. Also, no new 
instructions that require specifier calculations can be implemented 
without modification to the IR decode logic. 

In order to do optimizations of register to register and short literal 
to register, some additional information is passed: 

1. DST R Mode H - Indicates that specifier two (if any) is R 
mode and R is not PC. 

2. IMMED L - Indicates that specifier one is (PC)+. 

3. VAX SL L - Indicates that specifier one is a short liTeral. 

4. R Mode H - Indicates that specifier one is R mode and R is 
not PC. 

5. BO VAL (1) H - Indicates that the eight bits of opcode 
contain valid information. 

6. Bl VAL (1) H - Indicates that the specifier position in the 
instruction buffer contains valid data, specifier are valid. 



CHAPTER 5 
INTERRUPTS & EXCEPTIONS 



This chapter discusses interrupts, exceptions, machine halts and the 
UTRAP function. 



5.1 INTERRUPTS 

Interrupts are the notification of events in the system which require 
a change in the flow d*f control and are generally independent of the 
currently executing process. They are characterized by the following: 

1. Interrupts always occur at the end of instructions or during 
well defined points of long iterative instructions. 

2. Interrupts always push two long-words of state on either the 
kernel or interrupt stacks consisting of the PSL and PC of 
the next instruction. 

3. Interrupts always cause the processor to raise its Interrupt 
Priority Level (IPL) to that of the highest Interrupt 
Priority Request (IPR) . 



5.1.1 Interrupt Priority Level (IPL) 

There are 32 IPL levels defined within the processor and for an IPR to 
be serviced it must be greater than the IPL level of the current 
process. The IPL is a five bit field in the Processor Status Longword 
register (PSL). 
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There are several methods for changing the current IPL level: 

1. An MTPR instruction is executed in kernel mode to the IPL 
register. This will load a 5 bit number defined in the 
instruction operand into the IPL field of the PSL. 

2. The IPL field of the PSL is loaded from the stack in the 
execution of the REI instruction. 

3. The IPL field is set to one if current IPL is zero and the 
process is not executing on the interrupt stack (PSLIS=0) in 
the execution of the SVPCTX instruction. 

4. The IPL field is set to the highest Interrupt priority 
request active (IPRA) level during the execution of the 
interrupt sequence. 

5. The IPL field is set to IPL IF (highest priority) in the 
execution of the exception sequence for Kernel Stack Not 
Valid and Machine Check Faults. 



5.1.2 System Control Block 

The system control block is a page in memory containing the vectors by 
which interrupts and Exceptions are dispatched to the appropriate 
service routines. The system control block page is pointed to by the 
System Control Block Base reg (SCBB) located in the internal processor 
register space and accessed with the MTPR and MFPR instructions. 

The processor micro code insures that bit 31 and bits 8 thru of the 
SCBB are always loaded with zeroes. 



5. 1. 3 Vectors 

A vector is a longword in the system control block which is used to 
point to the interrupt or exception service routine and which 
describes how the event is to be serviced. The vector is formed by 
adding the contents of the SCBB register to a nine bit hardware 
generated vector which is dependent on the event being serviced. 
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The low two bits of the contents of the vector fetched from the system 
control block contain a code which indicates how the event is to be 
serviced as follows: 

Code Operation 



Service event on the kernel stack unless 

already on the Interrupt stack (PSL 
IS=1) 

1 Service event on the Interrupt stack 

2 Service event in WCS. Bits 15:02 are a 

parameter to service routine 

3 HALT 



5.1.4 Interrupt Requests and their Vectors 

Interrupt requests are sampled by the micro code during the execution 
of each instruction and if the IPR level is greater than the IPL and 
no exceptions occur during the instruction a branch at FORK A in the 
flows is taken to the interrupt micro-code service routine. Each 
interrupt request signal is a level which is sampled at CPT150 time in 
certain micro-instructions and is then prioritized and the highest 
priority request level is compared with the PSL IPL level. 

The hardware will generate the nine bit interrupt dependent vector in 
the Vector register which is available to micro-code but not to 
macro-code software. For SBI or Unibus interrupts the micro-code 
polls devices on the IPR level being serviced using the Interrupt 
Summary Read command. A sub-level bit mask of devices with pending 
interrupts at that IPR level is returned and written into the Vector 
register. Bits 31 thru 16 are prioritized in the Vector register 
according to lowest bit set has highest priority and are used to 
generate the 9 bit vector when a device interrupt is being serviced. 
Refer to section 1.7 , Registers used for Interrupt Servicing. 

Interrupt priority request occur on 31 levels with IPR IF the highest 
priority to IPR01 the lowest. IPR00 does not exist since the priority 
request must be greater than the IPL level of the processor to be 
serviced. The following is a list of interrupt conditions and their 
assigned vectors from highest priority to lowest priority. 



INTERRUPTS & EXCEPTIONS 



Page 5-4 



INTERRUPT PRIORITY REQUESTS 



Level 



I PR 


IF 


I PR 


IE 


I PR 


ID 


I PR 


1C 


I PR 


IB 


I PR 


1A 


I PR 


19 


I PR 


18 


I PR 


17 


I PR 


16 


I PR 


15 


I PR 


14 


IPR 


OF 


I PR 


OE 


IPR 


OD 


IPR 


OC 


IPR 


OB 


IPR 


OA 


IPR 


09 


IPR 


08 


IPR 


07 


IPR 


06 


IPR 


05 


IPR 


04 


IPR 


03 


IPR 


02 


IPR 


01 



Condition 



NONE ASSIGNED 

CPU POWER FAIL 

CPU TIMEOUT 

SB I FAULT 

SB I ALERT 

CRD/RDS 

SBI SILO COMPARE 

INTERVAL TIMER 

SBI REQ7/UNIBUS BR7 

SBI REQ6/UNIBUS BR6 

SBI REQ5/UNIBUS BR5 

SBI REQ4/UNIBUS BR4 

CONSOLE TERM. REC. 

CONSOLE TERM. XMIT. 

SOFTWARE REQ OF 



M 
It 
H 
H 

n 

H 
•t 

n 
n 

■ 
if 
n 

n 
n 



OE 
OD 
OC 
OB 
OA 
09 
08 
07 
06 
05 
04 
03 
02 
01 



or AST DEL. 



Vector 



OC 

60 

5C 

58 

54 

50 

CO 
1C0-1FC 
180-1BC 
140-17C 
100-13C 

F8 

FC 

BC 

B8 

B4 

BO 

AC 

A8 

A4 

AO 

9C 

98 

94 

90 

8C 

88 

84 
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5.1.5 Description of Interrupt Conditions 

5.1.5.1 CPU Power Fail - This interrupt occurs if a power fail 
warning Is received for the processor (AC LO) or from a critical 
system element (SBI FAIL) . Critical system elements include the SBI 
Clock circuitry, SBI terminators, Bootstrap Memories or Main Memory 
(in the standard configuration). There will be a guaranteed 5 
millisecs of good power after the assertion of this interrupt. This 
interrupt may occur immediately after a power up sequence has begun; 
however, at least 5 millisecs is guaranteed from the assertion of the 
Power Fail until the possibility of a power up sequence is allowed. 

This interrupt is cleared by hardware/micro-code and requires no 
macro-code intervention. 



5.1.5.2 CPU Timeout - This interrupt occurs if the processor attempts 
to write data into a non-existing physical address or receives an ERR 
confirmation on the SBI Bus for the second longword during an extended 
read operation. This may be caused k by software if the memory mapping 
is incorrectly set up or by a hardware failure. 

NOTE 

CPU timeout interrupts do not 
necessarily occur during the instruction 
which caused them since the processor is 
allowed to continue execution while an 
SBI write cycle is pending. 



No additional state information is saved on the stack other than the 
PC and PSL at the time of the interrupt. Error status will be latched 
in the SBI ERROR and SBI TIMEOUT ADDRESS registers. This interrupt is 
cleared by macro-level software by a write ones to clear operation on 
the CP TIMEOUT or IB TIMEOUT bits in the SBI ERROR register. 



5.1.5.3 SBI Fault - The SBI Fault interrupt occurs if an SBI bus 
error was detected by any device on the bus including the processor. 
If the processor detects a fault condition which prevents the 
completion of a read cycle for the CPU an exception condition is also 
generated. Generally this appears as a Read Timeout Machine Check 
exception. 

This interrupt is cleared by macro-level software by clearing the 
Fault Interrupt bit in the processor's FAULT/STATUS register which 
also unlocks the Fault status in each device. This interrupt will 
occur only if enabled in that register. 
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5.1.5.4 SBI Alert - This interrupt occurs when a device which does 
not contain SBI Request sequencing logic wishes to interrupt the 
processor and may be caused by device power fail, device power up, or 
dangerous environmental conditions in the device. Currently main 
memories in non-standard configurations use this interrupt to report 
changes in it's power status. 

This interrupt is cleared by macro-level software by clearing the 
Alert status bits in each device's configuration register. 



5.1.5.5 CRD/RDS - The Corrected Read Data (CRD) interrupt is asserted 
if the processor received read data which had been corrected by main 
memory. The Read Data Substitute (RDS) interrupt is asserted if the 
processor received uncorrected read date on a read cycle to the 
Instruction Buffer. If during the execution of instructions from the 
Instruction Buffer a change in program flow is encountered (branch, 
jump, etc.) before the bad data is used this interrupt will remain 
asserted. However, if an attempt is made to use the bad data an 
exception will occur and the RDS interrupt removed. 

These interrupts occur only if enabled in the processor's SBI ERROR 
register and must be cleared by macro-level software by writing ones 
to clear to the CRD, RDS, or IB RDS bits in that register. 

Additionally the software must clear the error condition in the memory 
configuration register if continued logging of errors and recording of 
address information is desired. 



5.1.5.6 SBI SILO Compare - This interrupt occurs when a match is 
detected on particular signal fields of the SBI bus. The signal field 
being checked can be program selected by control bits in the SILO 
COMPARATOR register. The previous 15 cycles on the SBI bus will be 
latched in the SILO register for interrogation by software. 

This interrupt will occur only if enabled in the SILO COMPARATOR 
register and must be cleared by macro-level software by writing a one 
to clear to the Silo Lock bit in that register. 



5.1.5.7 Interval Timer - This interrupt will occur when the Interval 
Count register overflows. This interrupt will occur only if enabled 
in the Clock Control Status register and must be cleared by 
macro-level software by writing the Interrupt Request bit in that 
register. 
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5.1.5.8 External Device Interrupts - External device interrupts occur 
at IPR 17 to IPR 14 and correspond to SBI REQ7/UNIBUS BR7 to SBI 
REQ4/UNIBUS BR4 levels respectively. These interrupts result from 
device completion, device errors, and important device status changes. 

When an external device interrupt is being serviced in micro-code the 
processor will issue an Interrupt Summary Read command at the serviced 
level to poll devices with pending interrupts at that level. A bit 
pair mask is returned on bits 31, 15 to bits 17, 01 indicating devices 
needing service. 

The hardware/micro-code will prioritize the returned data according to 
lowest bit set is highest priority and generate an interrupt vector 
for that level and highest priority device. 

Generally, device interrupts must be enabled and always require 
macro-level software intervention to clear the interrupt. 



5.1.5.9 Console Terminal Interrupts - The console terminal receive 
interrupt occurs when the Done bit in the RXCS register is set. The 
interrupt enable bit must be set in that register for the interrupt to 
occur. 

The console terminal transmit interrupt occurs when the RDY bit in the 
TXCS register is set. Likewise, the interrupt enable bit must be set 
in that register for the interrupt to occur. The receive interrupts 
has higher priority than the transmit interrupt. 

These interrupts are cleared by hardware/micro-code and requires no 
macro-code intervention. 



5.1.5.10 Software Interrupts - There are 15 interrupt priority 
requests for use by the software, IPR OF to IPR 01. The Software 
Interrupt Summary Register (SISR) contains l's in bit positions 15 
thru 01 corresponding to levels IPR OF to IPR 01 respectively with 
pending interrupts. Bits 20 thru 16 of the SISR contain the level of 
the highest interrupt priority request active (IPRA) of both the 
hardware and software levels. 

Macro-level software may book a request by using the MTPR instruction 
and writing a bit per request desired to the SISR or by writing the 
level number of a request to the Software Interrupt Request Register 
(SIRR) . Using the SIRR register to book a software request is 
preferred since it will not inadvertently clear other requests 
pending. Writing the SISR mainly occurs when restoring state 
information after a power fail. 

Micro-code will interpret writes to the SIRR as a bit set operation to 
the SISR. The mask generator in the CPU data paths can be used to 
decode the request level desired. 
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During the execution of the REI instruction the micro-code compares 
the current mode bits in the new PSL image with the asynchronous 
system trap level (ASTLVL) in the ASTR register. If the two bit 
current mode is greater than the three bit ASTLVL an AST is delivered 
at IPR02. This is performed by the micro-code doing a bit set to the 
SISR before completing the execution of REI. 

The micro-code/hardware will clear the software interrupt level being 
serviced by reading the SISR to determine the priority (IPRA) , 
decoding the level in the mask generator of the data paths, and 
performing a bit clear operation in the SISR. No macro-level software 
intervention is required. 



5.1.6 UWORD Control for Interrupts 

There is a two bit Uword field designated Uword Interrupt and 
Exception control (UIEK) which is used to monitor and acknowledge 
interrupt conditions. The functions available are as follows: 

UIEK 

NO-OP 

1 Interrupt Strobe (ISTR) 

2 Interrupt Acknowledge (IACK) 

3 Exception Acknowledge (EACK) 



5.1.6.1 Interrupt Strobe - The ISTR function is used to clock the 
state of interrupts at IPR IF to IPR10 and cause a new priority 
arbitration to occur. This is genrally done in the state prior to 
returning to the IRD state so that the Interrupt branch can be 
performed at Fork A. 

During the execution of long iterative instructions the ISTR function 
is used to periodically monitor Interrupt activity and to allow a 
subsequent micro branch to be performed on the Interrupt signal. 



5.1.6.2 Interrupt Acknowledge - The IACK function is used to clear 
the Power Fail, Console Term. Rec, and Console Term Xmit interrupts 
when they are being serviced by the micro-code routine. In addition 
the PSL is set to a predetermined state as follows: 

PSL: 



CMP 


<— 


TP 


<— 


FPD 


<— 


IS 


<— IS 
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CUR 


MOD 


< — 


(KERNEL) 


PRV 


NOD 


< — 


(KERNEL) 


IPL 




< — 


IPRA (IPR being serviced) 


DV 




< — 





FU 




< — 





IV 




< — 





T 




< — 





N 




< — 





Z 




< — 





V 




< — 





C 




< — 






5.1.7 Registers used for interrupt servicing 

5.1.7.1 Interrupt priority level register - IPLR - 

Processor Reg (PR) Address - 12 

Internal Data bus (ID) Address - not an ID reg. 

31 5 4 

I I I 

| o < > 1 IPL | 

I I I 



BITS NAME COMMENTS 



IPL Interrupt Priority Level IPL field of PSL 

read/write 



5.1.7.2 System control block base register - SCBB - 

PR Address - 11 
ID Address - 3B 



31 30 29 9 8 

III I 

I | | PFN I 0< >0 
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BITS 



NAME 



COMMENTS 



PFN 



Page Frame Number 



Holds the base physical 
address of the system control 
block page. Zero bits are 
always forced to zero when 
written, read/write 



5.1.7.3 Vector register, VECTOR - 

PR Address - Not available to software 
ID Address - D 



31 26 25 24 21 20 16 15 9 8 

II II I I 

I 0<->0| PRIOR | PRIOR | NUMB | 0< >0 I VECTOR 

I I VAL | | ONES | | 

BITS NAME COMMENTS 



PRIOR 
VAL 



PRIOR 



Priority Valid 



Priority Encode 



NUMB 
ONES 



VECTOR 



Number of Ones 



Interrupt Vector 



Indicates at least one 
bit was set when the last 
PRIOR field was determined. 
Read only. 

The priority encoded value 
of the last bit mask 
written into bits 31 to 16 
of the VECTOR register. 
Bit 31 represents the lowest 
priority (PRI0R=F) and 
bit 16 the highest (PRIOR=0) . 
Used to form the Vector, 
bits 8:0 when IPRA 
indicates an external 
interrupt. Read Only. 

The number of ones in the 
data last written into the 
Vector register bits 31 to 16 
Read only. 

A hardware generated 
number determined by 
IPRA. Read Only. 
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5.1.7.4 Asynchronous system trap level reg . - ASTR - 



PR Address - 13 

ID Address - Not an ID address 



31 



3 2 



0<- 



>0 | ASTLVL I 



BITS 



NAME 



COMMENTS 



ASTLVL Asynchronous System 
Trap Level 



Used to deliver AST interrupts 
in REI execution. Read/Write 



5.1.7.5 Software interrupt summary register - SISR - 



PR Address - 15 
ID Address - E 



31 



21 20 16 15 



1 

I 
I 



0<- 



I I 
>0 I IPRA | 

I I 0F<> 



I PR 



•>01 



BITS 



NAME 



COMMENTS 



IPRA 



I PR OF 
to 01 



Interrupt Priority 
Request Active 



Interrupt Priority 
Request OF to 01 



The level of the highest 
priority interrupt pending 
condition of the last 
Interrupt strobe time 
or write to SISR. 
Read Only 

Software interrupt request 
pending flags. 
Read/Write. 
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5.1.7.6 Software interrupt request register - SIRR - 

PR Address - 14 

10 Address - Not an ID register 



31 4 3 

I I 

| q< >0 I SIR i 

I I i 

BITS NAME COMMENTS 



SIR 



Software Interrupt 
Request 



The level of the request 
t.at software wishes to 
book in the SISR. An 
SIR=0 books no request. 
Write Only. 



5.2 EXCEPTIONS 

Exceptions are the notification of events which force a change in the 
flow of control for the currently executing process. Their 
characteristics are as follows: 



1. Exceptions 
instruction 
detected. 



occur in the 
during which 



middle or at -he end of an 
the exception condition had been 



Exceptions always push two long-words of state on either the 

kernel or interrupt stacks consisting of the PSL and PC of 

the instruction (sometimes the PC of the next instruction) . 

Additionally up to 16 longwords of exception parameter 
information may be pushed. 

Exceptions generally do not change the processor's IPL level. 
Only for Kernel Stack Not Valid and Machine Check Faults is 
the IPL altered in which case it is forced to IPL IF (highest 
priority) . 



Exceptions which occur while disabled do not cause an 
exception when subsequently enabled. Arithmetic traps are 
the only exceptions which can be disabled. 
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5.2.1 Classes of exceptions 

Exceptions may fall into three categories depending upon when they 
occur and how they leave the machine state. The three classes are 
Traps, Faults, and Aborts. 



5.2.1.1 Traps - A trap is an exception condition which occurs at the 
end of the instruction. The PC saved on the stack is that of the next 
instruction. 



5.2.1.2 Faults - A fault is an exception which occurs in the middle 
of an instruction, but which leaves memory and the general registers 
in the same state as at the beginning of the instruction. The PC 
saved on the stack is that of the instruction in which the fault was 
detected so that the instruction may be restarted when the fault 
condition is eliminated. 



5.2.1.3 Aborts - An Abort is an exception which occurs in the middle 

of an instruction but potentially leaves the registers and memory 

indeterminate, such that the instruction cannot be correctly 

restarted. The PC saved on the stack does not necessarily point to 

the beginning of the next instruction. 



5.2.2 Exception conditions and their vectors 

Exception conditions are detected thru the use of two mechanisms in 
the micro sequencing control: 

1. ubranches - a unique micro state is reached by performing a 

test of an exception condition using the UBEN 

field of the Uword or by using the special 

micro call function to branch on a decision 
point (DPT). 

2. utraps - a hardware detected micro trap occurs which 

alters the normal machine flow and causes 
unique micro service routines to be executed. 

Each of the micro service routines will manufacture the exception 
vector called for using a generator set of constants from the UKMX 
function of the Uword. Likewise, the micro service routines will put 
together the necessary parameters to be saved on the stack from state 
information stored within the processor registers. Exception codes 
will be furnished by the UKMX function. 
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The following is a list of exception conditions, their class, and 
their assigned vectors. In most cases the exception conditions are 
mutually exclusive; however, in cases of conflict the exception 
condition detected by the utrap function will have higher priority. 



EXCEPTION CONDITIONS 



Condition 



MACHINE CHECK 
KERNEL STACK NOT VALID 
RESERVED DEC OPCODES* 
PRIVILEGED INSTRUCTIONS 
RESERVED CUSTOMER OPCODES 
RESERVED OPERANDS 
RESERVED ADDRESSING MODES 
ACCESS CONTROL VIOLATION 
TRANSLATION NOT VALID 
TRACE TRAP 
BPT OPCODE 

COMPATABILITY MODE TRAP 
ARITHMETIC TRAP 
CHMK OPCODE 
CHME OPCODE 
CHMS OPCODE 
CHMU OPCODE 



Vector 


Class 


04 


FAULT/ABORT 


08 


ABORT 


10 


FAULT 


14 


FAULT 


18 


FAULT/ABORT 


1C 


FAULT 


20 


FAULT 


24 


FAULT 


28 


FAULT 


2C 


FAULT 


30 


TRAP/ABORT 


34 


TRAP 


40 


TRAP 


44 


TRAP 


48 


TRAP 


4C 


TRAP 



5.2.3 Description of exception conditions 

5.2.3.1 Machine check - Raises IPL to IF - Machine check exceptions 
push additional parameters onto the stack to assist in the evaluation 
of the condition causing the abort. Refer to Chuck Mathis' MACHINE 
CHECK DESCRIPTION AND SPECIFICATION for a list of the parameters. 



5.2.3.1.1 Read timeout - Read timeouts occur when the processor is 
performing a read or interlock read command on the SBI bus. 

This exception is detected by the utrap function for data path cycles 
and by the ubranch function for IBUF cycles. 
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5.2.3.1.2 Read data substitute - Read Data Substitute errors occur 
when the processor is performing a read or interlock read on the SBI 
bus and the memory has returned uncorrected read data. 

This exception is detected by the utrap function for data path cycles 
and by the ubranch function for IBUF cycles. 



5.2.3.1.3 Translation buffer parity error - TBUF parity errors occur 
when the processor Is performing ii virtual address reference and 
memory mapping is enabled and a parity check on the translation buffer 
indicates an error. 

This exception is detected by the utrap function for data path cycles 
and by the ubranch function for IBUF cycles. 



5.2.3.1.4 
processor 
the cache 



Cache parity error - Cache Parity errors 
is performing a read memory reference and 
indicates an error. 



occur when the 
a parity check of 



This exception is detected by the utrap function for data path cycles 
and by the ubranch function for IBUF cycles. 



5.2.3.1.5 Control store parity error - This error condition occurs 
when the micro machine detects a parity error in the next 
micro-instruction and may cause a Machine Check Abort at any time 
(including during the halt state while in console wait). 

This exception is detected by the utrap function. 



5.2.3.1.6 Illegal Machine Sequence Error - This error condition 
occurs if an illegal micro-instruction is reached and will generally 
indicate a hardware failure in the instruction decode circuitry. 



This exception is detected by the ubranch function. 
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5.2.3.2 Kernel stack not valid - Raises IPL to IF - This exception is 
reported it a Translation Not Valid or Access Control Violation Fault 
would have occurred while pushing onto the Kernel stack in the 
exception, interrupt, or CHMX micro flows. The vector for this 
exception should define servicing on the interrupt stack. 

No additional parameters are pushed for this exception. This 
exception is detected by the ubranch function. 



5.2.3.3 Reserved DEC opcodes & priv. ingtr - Reserved Dec Opcodes are 

the following: W, 377 57 to W, 777 EF, FD to FF. Privileged 

Instructions are the following: Not Kernel Mode and HALT, MTPR, MFPR, 
LDPCTX, SVPCTX. 

No additional parameters are pushed for this exception. This 
exception is detected by the ubranch function. 



5.2.3.4 Reserved cust opcodes - Reserved Customer Opcodes are FC. No 
additional parameters are pushed for this exception. This exception 
is detected by the ubranch function. 



5.2.3.5 Reserved operands - No additional parameters are pushed onto 
the stacFI This RSVD OPERAND type can be determined by the OPCODE 
pointed to by the pushed PC. 



5.2.3.5.1 Illegal floating number - Fault - A floating operand with 
sign=l and exponent=0. 

Occurs in: MOVF, MOVD, MNEGF, MNEGD, CVTFX, CVTDX, CVTRFL, CVTRDL, 
CMPF, CMPD, TSTF, TSTD, ADDF(2,3), ADDD(2,3), SUBF(2,3), SBUD(2,3), 
MULF(2,3), MULD(2,3), DIVF(2,3), DIVD(2,3), EMODF, EMODD, POLYF, 
POLYD, ACBF, ACBD. 

This exception is detected by the utrap function when the UMSC field 
calls for - Check Float Operand. 



5.2.3.5.2 Bit field too wide - Fault - Size operand is greater than 
32 or less than or when the bit field is located in a register with 
position operand greater than 31 or less than 0. 
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Occurs in: EXTV, EXTZV, INSV r CMPV, CMPZV, FFC, FFS, BBS, BBC, BBSS, 
BBSC, BBCS, BBCC, BBSSI, BBCCI. 

This exception is detected by the ubranch function. 



5.2.3.5.3 Illegal entry mask - Fault - Unspecified 
Occurs in: CALLG, CALLS 

This exception is detected by the ubranch function. 

5.2.3.5.4 PSW MBZ FIELD not zero - Fault - Bits 15:08 of the new PSW 
value is non-zero. 

Occurs in: RET, BISPSW, BICPSW 

This exception is detected by the ubranch function. 

5.2.3.5.5 Illegal PCB entry - Abort - The MBZ fields of the PCB+84 
and PCB+92 are non-zero. 

Occurs in: LDPCTX 

This exception is detected by the ubranch function. 

The PC pushed on the stack points to the opcode. 



5.2.3.5.6 Illegal PSL image - Fault - The new PSL from the stack did 
not have the correct format. 

Occurs in: REI 

This exception is detected by the ubranch function. 



5.2.3.5.7 Illegal processor reg - Fault - The internal processor 
register address does not exist. 

Occurs in: MTPR, MFPR 

This exception is detected by the ubranch function. 
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5.2.3.5.8 Decimal string too long - Fault - Length operand is greater 
than 31 or less than 0. 

Occurs in: MOVP, CMPP(3,4), ADDP(4,6), SUBP(4,6), MULP, DIVP, CVTLP, 
CVTPL, CVTPN, CVTNP, ASHP. 

This exception also occurs if an invalid numeric digit (an ASCII 
character other than thru 9) is encountered. 

Occurs in: CVTNP 

This exception is detected by the ubranch function. 



5.2.3.5.9 Reserved pattern operator - Fault - More input digits or 
less input digits are requested by the pattern than are specified or 
an unimplemented or reserved pattern operator is encountered. 

Occurs in: EDITPC 

This exception is detected by the ubranch function. 

The PC pushed on the stack points to the opcode. 



5.2.3.6 Reserved addressing modes - Fault - One of the following 
addressing" modes was encountered (luring the evaluation of an operand 
specifier: 

Specifier Situation Illegal 

Short Literal Mode Modify, write, address source, or within 

index mode. 

Register Mode Address source, or within index mode. 

Index Mode Within index mode, or with PC as index. 

No additional parameters are pushed for this exception. 

This exception is detected by the ubranch function. 



5.2.3.7 Access control violation - Fault - The exception occurs when 
the processor is performing a virtual reference and the protection 
code for that page found in the translation buffer does not allow 
access for the type of reference being performed (read or write) . In 
the current mode (Kernel, Exec, Super., or User). 
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An access control violation also occurs if during the translation 
process the micro-code discovers that the page frame number of the 
Virtual Address (VA(29:09) for per process address space and VA(30:09) 
for system address space) is outside the bounds as specified in that 
address space* s length register. 

Additional parameters pushed include: 



1. Virtual Address 



2. Fault Parameter 



- VA reg. for data path cycles & VIBA for 
IBUF cycles. 

- location in microflows & ubranch. 



31 03 02 01 00 

I I WRITE OR | REFERENCE I LENGTH | 

| < >0 | MODIFY | TO | VIOLATION | 

I I ACCESS | PTE | OCCURRED I 

The protection violation is detected by the utrap function for data 
path cycles and the ubranch function for IBUF cycles. The length 
violation is detected by the ubranch function and the virtual address 
is always located in VA. 



5.2.3.8 Translation not valid - Fault - The exception occurs when the 
processor is performing a virtual reference and if during the 
translation process (due to a TBUF miss utrap) an invalid page table 
entry (VALID bit=0 in PTE) is encountered. 

Additional parameters pushed include: 

1. Virtual Address - VA register. 

2. Fault Parameter - location in microflows & ubranch. 



31 03 02 01 00 

I I WRITE OR | REFERENCE 1 I 

I 0< >0 | MODIFY | TO I | 

I I ACCESS | PTE | | 

The translation process is begun by the utrap function for data path 
cycles and by the ubranch function for IBUF cycles. If an IBUF cycle 
needs translation then the VIBA is placed in the VA register and the 
process begun. If during the translation process this exception is 
detected by the ubranch function the VA register always contains the 
correct virtual address. 



INTERRUPTS & EXCEPTIONS Page 5-20 

5.2.3.9 Trace trap - TRAP - This exception occurs at the end of every 
instruction which Has the T bit in PSL set at the beginning of the 
instruction. If enabled this trap must occur even if exception or 
interrupts occur for the instruction being executed. 

The following instructions handle Trace Traps in special ways: 

RET, CHMX, REI, BISPSW, & BICPSW, CALL 

The trap occurs at Fork A using the ubranch function if the trap 
pending TP bit in PSL was set Upon entering the IRD micro-state. At 
the end of the IRD micro-state the T bit is sampled and if set the TP 
bit is set. Microcode can set or clear TP and T during the execution 
of instruction which handle Trace Traps in a special way to get the 
proper results. 

No additional parameters are pushed for this exception. 



5.2.3.10 BPT opcode - FAULT - This trap occurs when the BPT opcode is 
encountered in the instruction stream. 

No additional parameters are pushed. 

This condition is detected by the ubranch function. 



5.2.3.11 Compatability mode trap - TRAP/ABORT - This trap occurs when 

a reserved" opcode or an" illegal instruction is encountered when 

executing instructions in compatability mode. The following is a list 
of opcodes (in octal) which trap: 

HALT, WAIT, RESET, SPL, MARK, FADD, FSBU, FMUL, FDIV, 17XXXX, 000007, 
000077, 000210 to 000227, 007000 to 007777, 075040 to 076777, 1064000 
to 106477, 106700 to 107777, IOT, BPT, EMT, TRAP, JMP*DM0, JSR*DM0. 

In addition a Compatability mode Abort may occur if an odd address 
error is detected during the following memory references when in Comp. 
Mode: 

1. Any reference with VA00=1 and not a byte instruction being 
executed. 

2. Any opcode fetched from an unaligned word address. 
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3. The address fetch in the evaluation of addressing modes 3, 5, 
and 7. 

4. The index word fetch in the evaluation of addressing modes 6 
and 7. 

Additional parameters pushed include: 

1. Trap Code: - location in micro-flows 

#0 RSVD or Illegal Opcode 

#1 IOT opcode 

#2 BPT opcode 

#3 EMT opcode 

#4 TRAP opcode 

#5 ODD ADDRESS ERROR 

Detection of the special opcodes for this exception is accomplished 
with the ubranch function and will result in a Trap. 

Odd address errors are detected using the utrap function and will 
cause an ABORT since the PC pushed onto the stack is not necessarily 
that of the next instruction and that the instruction cannot be 
restarted. 



5.2.3.12 Arithmetic trap - TRAP - This trap occurs when an overflow 

or underflow condition is detected during the execution of 

instructions and the particular trap condition for that instruction 

has been enabled by the DV, FU, and IV enable bits in the PSL. The 
instruction is always completed. 

The following trap conditions are detected for the instructions 
indicated: 



1. Integer Overflow - Enabled by IV 

Occurs in: MNEGB,W,L; CVTWB,LB,LW; ADD B(2,3) f W(2,3), 
L(2,3); INC B,W,L; ADWC; SVB B(2 f 3), W(2,3), L(2,3); DEC 
B,W f L; SBWC; MUL B(2,3), W(2,3), L(2,3); DIV B(2,3), 
W(2 f 3), L(2,3); EDIV; ASHL; ASHQ; CVTF B,W,L; CVTD 
B,W,L; CVTRFL; CVTRDL; EMODF; EMODD; ACB B f W,L; AOBLEQ; 
AOBLSS; SOBGEQ; SOBGTR; CVTPL. 

2. Integer Divide by Zero - Always Enabled 
Occurs in: DIVB(2,3), W(2,3), L(2,3); EDIV 
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3. Floating Overflow - Always Enabled 

Occurs in: CVTDF; ADD F(2,3), D(2,3); SUB F(2,3), D(2,3); 
MUL F(2,3), D(2,3); DIV F(2,3), D(2,3); PLOY F,D; ACB F,D. 

4. Floating Divide by Zero - Always Enabled 
Occurs in: DIVF(2,3), D(2,3). 

5. Floating Underflow - ENabled by FU 

Occurs in: ADD F(2, 3) , D(2,3); SUB F(2,3), D(2 r 3); MUL 
F(2,3), D(2,3); DIV P(2,3), D(2,3); EMOD F,D; PLOYF,D; 
ACB F,D. 

6. Decimal Overflow - Enabled by DV 

Occurs in: EDITPC; ADDP(4,6); SUBP(4,6); MULP; DIVP; 
CVTLP; CVTPN; CVTNP; ASHP; 

7. Decimal Divide by Zero - Always Enabled 
Occurs in: DIVP 

Additional parameters pushed include: 

1. Trap Code: - CPU ERROR/STATUS REG 

#1 Integer Overflow 

#2 Integer Divide by Zero 

#3 Floating Overflow 

#4 Floating Divide by Zero 

#5 Floating Underflow 

#6 Decimal Overflow 

#7 Decimal Divide by Zero 

This trap is detected by the ubranch function. 



5.2.3.13 CHMX opcodes - At the completion of execution of the CHMK, 
CHME, CHMS, and CHMU instructions a trap is performed. 

Additional parameters pushed include: 

1. Sign extended operand - D register. 

This trap is detected by the ubranch function. 
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5.2.4 Acknowledging exceptions 

Most of the exception conditions do not require special action by the 

micro-code to complete the exception service code. Certain errors, 

arithmetic traps, and trace traps do, however, require special 
servicing. 



5.2.4.1 Error acknowledging - The micro-code must clear the following 
error status bits in the indicated register for error logging to 
continue. 



1. Read Timeout - SBI ERROR REG. 

2. READ DATA SUBSTITUTE - SBI ERROR REG. 

3. TBUF PARITY ERROR - TBI REG. 

4. CACHE PARITY ERROR - CACHE PARITY ERR REG, 

5. CS PARITY ERROR - CPU ERR/STATUS REG. 



5.2.4.2 Arithmetic trap acknowledging - The micro-code must clear 
pending arithmetic traps after they are serviced or when other 
exceptions occur, particularly those which restart the instruction. 

The method for clearing these conditions will be by writing zeroes to 
the trap code in the CES register. 



5.2.4.3 Trace trap acknowledging - The micro-code must clear the TP 
bit in the PSL to allow the next instruction to be executed without 
another Trace Trap occurring first. 

In order that exception conditions can properly be serialized the TP 
bits must be set to the proper state when pushing the PSL on the stack 
if a Trace Trap is pending while servicing other exceptions. 
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5.2.4.4 UWORD control for exceptions - The UIEK field of the UWORD 
provides an exception acknowledge function (EACK) which sets the PSL 
into the following state: 

PSL: CMP < — 

TP < — 

FPD < — 

IS <— IS 
CUR MOD < — KERN 
PRV MOD < — CUR MOD 

IPL <-- IPL 

DV <— 

FU <— 

IV <~ 
T <-- 
N <— 
Z <-- 

V <-- 
C < — 



5.3 MACHINE^HALTS 

The halt state of the machine is defined as the micro-machine being in 
the CONSOLE WAIT state and responding only to console commands. If an 
exception occurs while executing any console command or while in the 
Console Wait state an exception routine will be initiated in which a 
branch is performed on a CONSOLE COMMAND MODE flag to prevent pushes 
to the stack. 



5.3.1 Halt conditions 

5.3.1.1 Halt Instruction - If a HALT instruction is executed while in 
Kernel Mode (PSL CURMOD-0) the machine halts. 



5.3.1.2 CNSL halt - At any time during the execution of instructions 
the console may request that the machine come to a HALT. This is 
performed by a CNSL HALT REQUEST being asserted and serviced as an 
interrupt which does not push onto the stack nor change the IPL level. 
A CNSL HALT is serviced below Exceptions and above all other 
Interrupts and only at the end of instructions. 
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5.3.1.3 CHMX instructions - If a CHMK, CHME, CHMS, or CHMU 
instruction Is encountered and the IS bit in PSL=1 then the machine 
comes to a halt before any execution of the instruction occurs. 



5.3.1.4 Interrupt stack not valid - If a Translation Not Valid or 
Access Control Violation Fault would have occurred while pushing onto 
the Interrupt stack in the exception or interrupt micro code service 
flows a machine halt occurs with INTR STACK NOT VALID reported. 



5.3.1.5 Halt code from vector - If an Interrupt or Exception occurs 
and the halt code is found in the Vector location then the CPU will 
halt after pushing the appropriate parameters onto the stack. 



5.4 UTRAP FUNCTION 

During the execution of micro-instructions the hardware detects 

certain error conditions and initiates a trap in micro-code to one of 

several service flows. The micro-PC is pushed onto the micro stack so 
that certain micro processes can be continued. 



5.4.1 UTRAP conditons and their vectors 

The following is a list of conditions and their relative priority 
(first is highest) which cause a utrap: 





CONDITION 


VECTOR 


1. 


SYSTEM INIT 


100 


2. 


ERRORS: 






CS PARITY 


10F 




ODD ADDRESS 


10E 




TIMEOUT 


10D 




READ DATA SUBSTITUTE 


IOC 




CACHE PARITY ERROR 


108 




TBUF PARITY ERROR 


107 


3. 


RESERVED FLOATING OPERAND 


106 


4. 


TBUF MISS 


105 


5. 


PROTECTION VIOLATION 


104 


6. 


MBIT 


103 


7. 


PAGE BOUNDARY 


102 


8. 


UNALIGNED DATA 


101 
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5.4.2 Description of utrap conditions 

5.4.2.1 System Init - DC LO is asserted for the CPU or DEAD is 
received from the SBI bus. 



5.4.2.2 Errors - Description of errors can be found in the sections 
on Exceptions . 



5.4.2.3 Reserved Floating Operand - This condition occurs when the 
UMSC fieT3 ol tEe Uword has the CHECK FLOAT OPERAND function and 
ALU15=1 With ALU(14:07)=0. 



5.4.2.4 TBUF Miss - This occurs when the processor is doing a virtual 
reference with memory mapping enabled (MME=1) and there is no address 
translation in the TBUF. 



5.4.2.5 Protection Violation - This occurs when the processor is 

doing a virtual reference with memory mapping enabled (MME=1) and the 

TBUF entry indicates the page being referenced is protected from the 
mode and reference type being used. 



5.4.2.6 MBIT - This occurs when the processor is doing a virtual 
write reference with memory mapping enabled (MME=1) and the TBUF entry 
indicates the the page should be marked as being modified. 



5.4.2.7 Page Boundary - This occurs when the processor is doing a 
virtual reference with memory mapping enabled (MME=1) and the data 
type will cause a reference across a page boundary. The micro-code 
will then probe the next page to insure that a Translation Not Valid 
or Access Violation Fault will not occur. 



5.4.2.8 Unaligned Data - This occurs when the processor is doing any 
memory reference and the data type indicates a second reference is 
required. Quad and Double data types are treated as two sequential 
longword references so that two UNALIGNED DATA uTRAPS will occur if 
the data is not on a longword boundary. 



INTERRUPTS & EXCEPTIONS Pa 9 e 5 " 27 

5.5 SERIALIZATION OF EVENTS AT FORK A 

The first decision point branch after the IRD state is used to perform 
Arithmetic and Trace Traps occurring for the previous instruction. In 
addition console halt requests and Interrupts are sampled. If one ot 
these conditions are to be serviced the PC must be backed up since it 
was advanced in anticipation of executing the next instruction. 

The following list is the priority of branches taken at Fork A so that 
the proper trap and interrupt sequencing can occur. 

Highest listed first: 

1. ARITHMETIC TRAP 

2. CNSL HALT REQUEST 

3. INTERRUPT 

4. TRACE TRAP 

5. IBUF STALL 

6. IBUF ERRORS 

7. OPCODES & SPECIFIERS 



CHAPTER 6 
MACHINE CHECK ABORT/FAULT/HALT 



6.1 MACHINE CHECKS 

A machine check function can be initiated by a hardware forced 
micro-trap, by the micro-code's testing for an I-buffer error on a 
memory reference, or by the firmware detecting a sequencing error. 

A machine check can be caused by any one of the following conditions: 

CONTROL STORE PARITY ERROR - 

This condition occurs when the hardware detects a control store 
parity error while reading a micro-word. A micro-trap is used to 
initiate the error handling micro-code. 

READ DATA SUBSTITUTE - 

Read data substitute (RDS) errors occur when the processor is 
performing a read or interlock read on the SBI bus and the memory 
has returned uncorrected read data. 

TRANSLATION BUFFER PARITY ERROR - 

TBUF parity errors occur when the processor is translating a 
virtual address for a virtual memory reference (MME-1) , and a 
parity error occurs on data read-out of the translation buffer. 

CACHE PARITY ERROR - 

CACHE parity errors occur when the processor is performing a read 
memory reference and a parity check is detected on data read out 
of the cache. 
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READ TIMEOUT/SBI ERROR CONFIRMATION - 

Read timeouts and Error Confirmations occur when the processor is 
performing a read or interlock read command on the SBI bus and an 
SBI Error is detected as there is no response to the processor's 
read memory or I/O read reference. 

NOT SUPPOSE-TO-BE-HERE - 

When micro-code detects it has arrived at an illegal 
micro-address, it pushes that address onto the micro-stack and 
transfers control to the error handling micro-code. 

The IPL is raised to "IF" when any one of the above conditions occur. 

On CP memory reference errors, micro-traps are used to initiate the 
error handling micro-code. On I-Buffer memory reference errors, the 
micro-code detects on specifier evaluations the error and transfers 
control to the error handling micro-code. 

See the "INTERRUPTS & EXCEPTIONS SPECIFICATION", Rev. B for addition 
details on the hardware implementation of the above micro-traps and 
"IBUF SPECIFICATION" for hardware specs for the micro-branch on IBUF 
memory reference errors. 



6.2 INSTRUCTION ABORTS 

Instructions are aborted on the following cases: 

1. Control store parity error micro-traps 

2. Error occurs during memory management micro-code 

3. Error occurs during interrupt or exception micro-code 

4. "Not suppose to be here", detected by micro-code. 

The "NESTED ERROR" flag is used by users of the memory management 
micro-routines to tell the error handling micro-code to do an abort 

sequence. 
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6.3 INSTRUCTION FAULTS 

On RDS, TBUF parity error, CACHE parity error, or a READ TIME 
OUT/ERROR Confirmation; the instruction being executed (or setup) 
will be faulted if an abort or halt situation does not exist. 

This will allow selected instructions to be retryed by the operating 
software. For the instructions that are retryable, see Appendix A. 

The "EFP" (Error First Pass) flag is left set on faults and must be 
reset by the operating software before continuing. Manually writing 
zeros to ID[SBI FAULT] clears it, and software can reset it using the 

MTPR ( 0) instruction. It is also cleared by system initialization. 

(If it is not cleared, the CPU will be halted on the next machine 
check) . 



6.4 INSTRUCTION HALTS 

The instruction being executed (or setup) will be halted if, 



1. Processor is in Console Mode. 

2. "EFP" (Error First Pass) flag is set on entry to the error 
handling micro-code. 

3. A memory error occurs while attempting to push parameters on 
the kernel or interrupt stack. (Write timeout or Error 
Confirmation) 

The "EFP" (Error First Pass) flag is set and tested by the error 
handling micro-code to determine the halt situation. This flag is a 
R/W bit in the "SBI FAULT" status register, bit 25. 



6.5 ERROR LOGOUT 

On Machine Checks, the Error Handling micro-code will attempt to log 
out the relevant status registers and the VA Register as parameters on 
the stack selected by the Machj ine Check Exception Vector. (Suggest 
that software always use Interrupt stack to keep from losing error 
information if stack is not resident or valid.) 

Also two additional longword parameters are pushed on the stack which 
are : 
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SUMMARY PARAMETER: 



BYTE#0, 



Identification of the machine check 
fault/abort sequence. 

CODE 



that initiated the 



00 - CP READ TIMEOUT/SBI ERROR CONFIRMATION FAULT 



02 
03 
05 
0A 
0C 
0D 
OF 
Fl 
F2 
F3 
F4 
F5 
F6 



CP TBUF PARITY ERROR FAULT 

CP CACHE PARITY ERROR FAULT 

CP RDS FAULT 

IB TBUF PARITY ERROR FAULT 

IB RDS FAULT 

IB READ TIMEOUT/SBI ERROR CONFIRMATION FAULT 

IB CACHE PARITY ERROR FAULT 

CS PARITY ERROR ABORT 

CP TBUF PARITY ABORT 

CP CACHE PARITY ERROR ABORT 

CP READ TIMEOUT/SBI ERROR CONFORMATION ABORT 

CP RDS ABORT 

CP "NOT -SUPPOSE-TO BE HERE" ABORT 



BYTE#1, 



Flag noting that a CP timeout or 
interrupt was pending. 



CP Error Confirmation 



This flag will be set 
interrupt was pending. 



to a non-zero value if this 



The operating software must examine the previously logged 
out parameters to determine and handle these error 
interrupts. (This possible pending interrupt has been 
cleared in order to handle the machine check sequence. 
The logged-out information is the only record that it was 
pending) . 

BYTES 3&4 - MBZ 
LENGTH PARAMETER 

BYTE#0 f Number of bytes logged out exclusive of this parameter 

BYTES #1-3 MBZ 
The layout and contents of the logout area on the stack as follows: 
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(1) 


28 | 
(HEX) I 


(2) 


SUMMARY PARAMETER I 


(3) 


CES 1 


(4) 


TRAPPED UPC 1 


(5) 


VA/VIBA | 


(6) 


D | 


(7) 


TBERO 1 


(8) 


TBER1 1 


(9) 


TIME.ADDR 1 


(10) 


! PARITY 1 


(11) 


I SBI.ERR 1 


(12) 


1 PC 1 


(13) 


I PSL 1 



SP: 



ERROR LOGOUT AREA MAP/SP 
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6.6 INITIALIZATION OF CP, TBUF, CACHE , & SBI STATUS REGISTERS 

The following status registers are initialized by the Error Handling 
micro-code. 

TBUF ERROR REG1 (TBER1) - 

Register is written to clear accumulated TBUF parity error 
information & FLUSH IB microrder is used to clear IB errors. 

SBI ERROR REG (SBI. ERR) - 

A one is written to CP Timeout also to clear CP Timeout and CPU 
Error Confirmation. 

FLUSH. IB is used to clear I-Buffer errors. 

Writing to CP timeout also unlocks the timeout address register. 

CACHE PARITY REG (PARITY) - 

Contents of this register are written to itself to clear the 
cache parity error bit. (Write one to clear type bit.) 



6.7 CPU/CONSOLE INTERFACE STATE 



Console Mode: 

The cpu will halt after leaving the error halt code in IDfD.SVJ. 
The information on the machine check is their respective 
error/status registers. "Note, Console Responsible for logging & 
clearing these registers". 

Double Error Halt: 



The cpu will halt if it finds on entry to the Error handling 
micro-code that "EFP" is set. 

The information on the first error will be in ID[T0-T9] and 
U-STACK (trapped micro-addresses). See layout of ID[T0-T9]. 
Unpredictable on CS Parity errors. 

The information on the 2nd error will be in the associated 
error/status registers. 

The cpu will be halted after leaving a double error halt code in 
ID[D.SV]. 
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SUMMARY PARA. 



CES 
TRAPPED UPC 



VA/VIBA 
D-REG 



TBERO 
TBER1 



TIME.ADDR 
PARITY 
SB I. ERR 



TO 
Tl 
T2 
T3 
T4 
T5 
T6 
T7 
T8 
T9 



Figure 7.1 First Error Info on Double Error Halts in ID-Registers 



6.8 HALT IDENTIFICATION CODES 

Values left in IDfD.SV] for printout by Console whenever the CPU 
halts. 



= Operation requested by console, completed successfully. 
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1 = Memory management fault, see <31-8> for specifics (on Console 

Request) . 

2 = Error occurred on Console Request. 

3 = Warm/Cold Start Power-up sequence completed (occurs on console 

"INIT" also) . 

4 = Interrupt Stack not valid. 

5 = CPU Double Error Halt (see Machine Mheck Abort/Fault/Halt Spec for 

details)!!! Sys Has Crashed! 

6 = Halt instruction. 

7 = Illegal I/E Vector Code/<1:0> 

8 = No user WCS (I/E vector specs user WCS). 

9 = Error interrupt (s) pending on "HALT" command. 
A « CHM halt. 

B = (open) 



NOTE 

4,5,7,8 codes represent system crashes 
and require a Sys Rebott to continue!!! 



6.9 RETRYABLE INSTRUCTION LIST 

See the attached list for instructions that are retryable and the 
specific information and conditions. A summary and interpretation is 
as follows: [applies only to CP Errors, all instructions faultable on 
IB Errors] 

INSTRUCTIONS THAT ARE NOT RETRYABLE ON CP ERRORS: 



ADDN4 


CVTNL? 


REI 


ADDN6 


CVTNP 


REMQUE 


ASHN 


CVTPN 


SUBN4 


CHME? 


EDITPC 


SUBN6 


CHMK? 


INSQUE 


SVPCTX 


CHMS? 


LDPCTX 


XFC 


CHMU? 


MOVN 




CMPN3 


MULN 




CMPN4 


POPR 




CVTLN 


PUSHR 
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There are also restrictions on retrying some instructions 
that are retryable. Restrictions are noted using notes on 
the attached list. 

[x] Means instruction is conditionally retryable. 

Some restrictions are: 

1. Cannot retry unaligned writes. 

The Error handling micro-code aborts all such cases. 

2. Instructions Referencing I/O Space 

Software required to decide if retryable or not. 

In addition these restrictions, the instructions with the 
following notes also have the added restrictions as noted. 

[2] Cannot retry any write. 

On the instructions noted, the operating software must 
examine the logged out information on the stack to determine 
if they were doing a write. If so they are not retryable. 

[3] Can cause a SBI Fault. 

On the instructions so noted, SBI fault will occur if the 
interlocked write is aborted because of a TB parity error. 
(Interlock timeout in unit receiving the previous interlock 
read). Operating software must determine that this case 
exists. 

[4] Machine check while pushing information on stack (Kernel) . 

The Error Handling micro-code aborts all such cases. 

[?] Means retryability to be determined later. 

[NR] Instruction is not retryable. 



9D ACBB ADD COMPARE AND BRANCH BYTE | x I 

6F ACBD ADD COMPARE AND BRANCH DOUBLE I X I 

4F ACBF ADD COMPARE AND BRANCH FLOATING I x 

Fl ACBL ADD COMPARE AND BRANCH LONG I X I 

3D ACBW ADD COMPARE AND BRANCH WORD | x I 

80 ADDB2 ADD BYTE 2 OPERAND I x I 

81 ADDB3 ADD BYTE 3 OPERAND I x I 

60 ADDD2 ADD DOUBLE 2 OPERAND I X I 

61 ADDD3 ADD DOUBLE 3 OPERAND I x I 

40 ADDF2 ADD FLOATING 2 OPERAND I X I 

41 ADDF3 ADD FLOATING 3 OPERAND I x I 
CO ADDL2 ADD LONG 2 OPERAND I x I 
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CI 

20 

21 

AO 

Al 

D8 

F3 

F2 

78 

F8 

79 

El 

E5 

E7 

E3 

IE 

IF 

EO 

E4 

E2 

E6 

13 

13 

18 

IE 

14 

1A 

8A 

8B 

CA 

CR 

B9 

AA 

AB 

88 

89 

C8 

C9 

B8 

A8 

A9 

93 

D3 

B3 

E9 

E8 

15 

IB 

19 

IF 

12 

12 

03 

11 

31 



ADDL3 

ADDN4 

ADDN6 

ADDW2 

ADDW3 

ADWC 

AOBLEQ 

AOBLSS 

ASHL 

ASHN 

ASHQ 

BBC 

BBCC 

BBCCI 

BBCS 

BCC 

BCS 

BBS 

BBSC 

BBSS 

BBSS I 

BEQL 

BEQLU 

BGEQ 

BGEQU 

BGTR 

BGTRU 

BICB2 

BICB3 

BICL2 

BICL3 

BICPSW 

BICW2 

BICW3 

BISB2 

BISB3 

BISL2 

BISL3 

BISPSW 

BISW2 

BISW3 

BITB 

BITL 

BITW 

BLBC 

BLBS 

BLEQ 

BLEQU 

BLSS 

BLSSU 

BNEQ 

BNEQU 

BPT 

BRB 

BRW 



ADD LONG 3 OPERAND I X I 

ADD NUMERIC 4 OPERAND I NR I 

ADD NUMERIC 6 OPERAND I NR | 

ADD WORD 2 OPERAND | X I 

ADD WORD 3 OPERAND | x I 

ADD WITH CARRY I [2] | 

ADD ONE AND BRANCH ON LESS OR EQUAL | x | 

ADD ONE AND BRANCH ON LES I X I 

ARITHMETIC SHIFT LONG I X I 

ARTHMETIC SHIFT NUMERIC I NR | 

ARITHMETIC SHIFT QUAD | [2] I 

BRANCH ON BIT CLEAR I X I 

BRANCH ON BIT CLEAR AND CLEAR I X I 

BRANCH ON BIT CLEAR AND CLEAR INTERLOCKED I 

BRANCH ON BIT CLEAR AND SET I X I 

BRANCH ON CARRY CLEAR I X I 

BRANCH ON CARRY SET I X I 

BRANCH ON BIT SET I X I 

BRANCH ON BIT SET AND CLEAR | X | 

BRANCH ON BIT SET AND SET | X | 

BRANCH ON BIT SET AND SET INTERLOCKED I [3] I 

BRANCH ON EQUAL I X I 

BRANCH ON EQUAL UNSIGNED I X I 

BRANCH ON GREATER OR EQUAL I X | 

BRANCH ON GREATER OR EQUAL UNSIGNED | X I 

BRANCH ON GREATER I X I 

BRANCH ON GREATER UNSIGNED I X | 

BIT CLEAR BYTE 2 OPERAND I X I 

BIT CLEAR BYTE 3 OPERAND I X I 

BIT CLEAR LONG 2 OPERAND | x | 

BIT CLEAR LONG 3 OPERAND I X | 

BIT CLEAR PROGRAM STATUS WORD I X I 

BIT CLEAR WORD 2 OPERAND I X I 

BIT CLEAR WORD 3 OPERAND I X I 

OPERAND | X | 

OPERAND | X I 

OPERAND | X | 

OPERAND | X I 



[3] 



BIT SET BYTE 2 

BIT SET BYTE 3 

BIT SET LONG 2 

BIT SET LONG 3 



OPERAND I X 
OPERAND | X 

I x I 

! x I 

I x I 



BIT SET PROGRAM STATUS WORD I X 1 

BIT SET WORD 2 

BIT SET WORD 3 

BIT TEST BYTE 

BIT TEST LONG 

BIT TEST WORD 

BRANCH ON LOW BIT CLEAR | X I 

BRANCH ON LOW BIT SET I X | 

BRANCH ON LESS OR EQUAL I X I 

BRANCH ON LESS OR EQUAL UNSIGNED I : 

BRANCH ON LESS I X I 

BRANCH ON LESS UNSIGNED I x I 

BRANCH ON NOT EQUAL I X I 

BRANCH ON NOT EQUAL UNSIGNED I X I 

BREAK POINT TRAP I [4] | 

BRANCH WITH BYTE DISPLACEMENT | x I 

BRANCH WITH WORD DISPLACEMENT I x I 
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10 

30 

1C 

ID 

FA 

FB 

8F 

CF 

AF 

BD 

BC 

BE 

BF 

94 

7C 

D4 

D4 

7C 

B4 

91 

29 

2D 

71 

51 

Dl 

35 

37 

EC 

Bl 

ED 

OB 

6C 

4C 

98 

99 

68 

76 

6A 

69 

48 

56 

4A 

49 

F6 

6E 

4E 

F9 

F7 

36 

26 

24 

6B 

4B 

33 

6D 



BSBB 

BSBW 

BVC 

BVS 

CALLG 

CALLS 

CASEB 

CAS EL 

CASEW 

CHME 

CHMK 

CHMS 

CHMU 

CLRB 

CLRD 

CLRF 

CLRL 

CLRQ 

CLRW 

CMPB 

CM PC 3 

CMPC5 

CMPD 

CMPF 

CMPL 

CMPN3 

CMPN4 

CMPV 

CMPW 

CMPZV 

CRC 

CVTBD 

CVTBF 

CVTBL 

CVTBW 

CVTDB 

CVTDF 

CVTDL 

CVTDW 

CVTFB 

CVTFD 

CVTFL 

CVTFW 

CVTLB 

CVTLD 

CVTLF 

CVTLN 

CVTLW 

CVTNL 

CVTNP 

CVTPN 

CVTRDL 

CVTRFL 

CVTWB 

CVTWD 



x 
x 



I x I 



-> 



I 



BRANCH TO SUBROUTINE WITH BYTE DISPLACEMENT I X 

BRANCH TO SUBROUTINE WITH WORD DISPLACEMENT I x 

BRANCH ON OVERFLOW CLEAR I X I 

BRANCH OF OVERFLOW SET I X I 

CALL WITH GENERAL ARGUMENT LIST I [2] I 

CALL WITH STACK I [2] I 

CASE BYTE I x I 

CASE LONG I X I 

CASE WORD I X I 

CHANGE MODE TO EXECUTIVE I ? I 

CHANGE MODE TO KERNAL I ? I 

CHANGE MODE TO SUPERVISOR I ? I 

CHANGE MODE TO USER I ? I 

CLEAR BYTE I X I 

CLEAR DOUBLE I [2] I 

CLEAR FLOAT I X I 

CLEAR LONG I x I 

CLEAR QUAD I [2] I 

CLEAR WORD I X I 

COMPARE BYTE I X I 

COMPARE CHARACTER 3 OPERAND 

COMPARE CHARACTER 5 OPERAND 

COMPARE DOUBLE I X I 

COMPARE FLOATING I X I 

COMPARE LONG I X I 

COMPARE NUMBERIC 3 OPERAND I 

COMPARE NUMBERIC 4 OPERAND I 

COMPARE VI ELD I x I 

COMPARE WORD I X I 

COMPARE ZERO-EXTENDED VI ELD I X I 

CALCULATE CYCLIC REDUNDANCY CHECK I X I 

CONVERT BYTE TO DOUBLE I [2] I 

CONVERT BYTE TO FLOAT I X I 

CONVERT BYTE TO LONG I X I 

CONVERT BYTE TO WORD I X I 

CONVERT DOUBLE TO BYTE | X I 

CONVERT DOUBLE TO FLOAT I X I 

CONVERT DOUBLE TO LONG I X I 

CONVERT DOUBLE TO WORD I X I 

CONVERT FLOAT TO BYTE I X I 

CONVERT FLOAT TO DOUBLE I [2] I 

CONVERT FLOAT TO LONG I x I 

CONVERT FLOAT TO WORD I X I 

CONVERT LONG TO BYTE I X I 

CONVERT LONG TO DOUBLE I [2] I 

CONVERT LONG TO FLOAT I x I 

CONVERT LONG TO NUMERIC I NR I 

CONVERT LONG TO WORD I X I 

CONVERT NUMERIC TO LONG I ? I 

CONVERT NUMERIC TO PACKED I NR | 

CONVERT PACKED TO NUMERIC I NR I 

CONVERT ROUNDED DOUBLE TO LONG I X I 

CONVERT ROUNDED FLOAT TO LONG I x I 
CONVERT WORD TO BYTE I X I 

CONVERT WORD TO DOUBLE I [2] I 
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4D 
32 
97 
D7 
B7 
86 
87 
66 
67 
46 
47 
C6 
C7 
27 
A6 
A7 
38 
7B 
74 
54 
7A 
EE 
EF 
EB 
EA 
00 
96 
D6 
B6 
FO 
OE 
17 
16 
06 
3A 
39 
92 
D2 
B2 
DB 
8E 
72 
52 
CE 
AE 
9E 
7E 
DE 
DE 
7E 
3E 
90 
28 
2C 
70 



CVTWF 

CVTWL 

DECB 

DECL 

DECW 

DIVB2 

DIVB3 

DIVD2 

DIVD3 

DIVF2 

DIVF3 

DIVL2 

DIVL3 

DIVN 

DIVW2 

DIVW3 

EDITPC 

EDIV 

EMODD 

EMODF 

EMUL 

EXTV 

EXTZV 

FFC 

FFS 

HALT 

INCB 

INCL 

INCW 

INSV 

INSQUE 

JMP 

JSB 

LDPCTX 

LOCC 

MATCHC 

MCOMB 

MCOML 

MCOMW 

MFPR 

MNEGB 

MNEGD 

MNEGF 

MNEGL 

MNEGW 

MOVAB 

MOVAD 

MOVAF 

MOVAL 

MOVAQ 

MOVAW 

MOVB 

MOVC3 

MOVC5 

MOVD 



CONVERT WORD TO 
CONVERT WORD TO 
DECREMENT BYTE 
DECREMENT LONG 
DECREMENT WORD 
DIVIDE BYTE 2 
DIVIDE BYTE 3 



FLOAT 
LONG | 
x I 
x I 
X I 
OPERAND 
OPERAND 



x 

x I 



I x I 



X 
X 



DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 
DIVIDE 



DOUBLE 2 
DOUBLE 3 
FLOATING 
FLOATING 



OPERAND | 
OPERAND | 

2 OPERAND 

3 OPERAND 



[2] 
[2] 



x 

X 



I x I 



X 
X 



I x I 



X 
X 



[2] I 



LONG 2 OPERAND 

LONG 3 OPERAND 

NUMERIC | NR| 

WORD 2 OPERAND 

WORD 3 OPERAND 
EDIT PACKED TO CHARACTER I NR I 
EXTENDED DIVIDE I [2] | 
EXTENDED MODULUS DOUBLE I [2] I 
EXTENDED MODULUS FLOATING I 
EXTENDED MULTIPLY I [2] | 
EXTRACT VI ELD | x I 
EXTRACT ZERO-EXTENDED VIELD 
FIND FIRST CLEAR BIT I X | 
FIND FIRST SET BIT I X | 
HALT | [4] | 
INCREMENT BYTE 
INCREMENT LONG 
INCREMENT WORD 
INSERT VIELD I 



I X | 



x 
x 

X 

I 



INSERT INTO QUEUE I NR I 
JUMP | X | 

JUMP TO SUBROUTINE I X 
LOAD PROGRAM CONTEXT I 



NR| 



I X | 



x 

X 

BYTE 
LONG 
WORD 



LOCATE CHARACTER 

MATCH CHARACTERS 

MOVE COMPLEMENTED 

MOVE COMPLEMENTED 

MOVE COMPLEMENTED 

MOVE FROM PRECESSOR 

MOVE NEGATED BYTE I 

MOVE NEGATED DOUBLE I [2] | 

MOVE NEGATED 

MOVE NEGATED 

MOVE NEGATED 

MOVE ADDRESS 

MOVE ADDRESS 

MOVE ADDRESS 

MOVE ADDRESS 

MOVE ADDRESS 

MOVE ADDRESS 

MOVE BYTE I X I 

MOVE CHARACTER 3 OPERAND 

MOVE CHARACTER 5 OPERAND 

MOVE DOUBLE | [2] | 



REGISTER | [2] 
x I 



FLOATING 
LONG | x 
WORD | x 
OF BYTE | 
DOUBLE 
FLOAT 
LONG I 
QUAD | 
WORD | 



OF 
OF 
OF 
OF 
OF 



x I 
I x 
x I 
x I 
x I 
x I 



X 
X 



I x I 
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50 

DO 

34 

DC 

7D 

2E 

2F 

BO 

9A 

9B 

3C 

DA 

84 

85 

64 

65 

44 

45 

C4 

C5 

25 

A4 

A5 

01 

75 

55 

BA 

OC 

OD 

9F 

7F 

DF 

DF 

7F 

3F 

DD 

BB 

02 

OF 

04 

9C 

05 

D9 

2A 

3B 

F4 

F5 

2B 

82 

83 

62 

63 

42 

43 

C2 



I x I 
x I 



MOVF MOVE FLOAT I X I 

MOVL MOVE LONG | X I 

MOVN MOVE NUMERIC I ? I 

MOVPSL MOVE PROGRAM STATUS LONGWORD I X I 

MOVQ MOVE QUAD I [2] I 

MOVTC MOVE TRANSLATED CHARACTERS I X I 

MOVTUC MOVE TRANSLATED UNTIL CHARACTER I X I 

MOVW MOVE WORD I x | 

MOVZBL MOVE ZERO-EXTENDED BYTE TO LONG I X I 

MOVZBW MOVE ZERO-EXTENDED BYTE TO WORD I x | 

MOVZWL MOVE ZERO-EXTENDED WORD TO LONG I X I 

MTPR MOVE TO PROCESSOR REGISTER I x I 

MULB2 MULTIPLY BYTE 2 OPERAND | x | 

MULB3 MULTIPLY BYTE 3 OPERAND | x I 

MULD2 MULTIPLY DOUBLE 2 OPERAND | [2] | 

MULD3 MULTIPLY DOUBLE 3 OPERAND I [2] I 

MULF2 MULTIPLY FLOATING 2 OPERAND I X I 

MULF3 MULTIPLY FLOATING 3 OPERAND | X I 

MULL 2 MULTIPLY LONG 2 OPERAND | x I 

MULL3 MULTIPLY LONG 3 OPERAND | X I 

MULN MULTIPLY NUMERIC I NR I 

MULW2 MULTIPLY WORD 2 OPERAND 

MULW3 MULTIPLY WORD 3 OPERAND I 

NOP NO OPERATION | X | 

POLYD EVALUATE POLYNOMIAL DOUBLE I [2] I 

POLYF EVALUATE POLYNOMIAL FLOATING I X 

POPR POP REGISTERS I NR I 

PROBER PROBE READ ACCESS I x I 

PROBEW PROBE WRITE ACCESS I x I 

PUSHAB PUSH ADDRESS OF BYTE | x I 

PUSHAD PUSH ADDRESS OF DOUBLE I x | 

PUSHAF PUSH ADDRESS OF FLOAT I x I 

PUS HAL PUSH ADDRESS OF LONG 

PUSHAQ PUSH ADDRESS OF QUAD 

PUSHAW PUSH ADDRESS OF WORD 

PUSHL PUSH LONG I x I 

PUSHR PUSH REGISTERS I NR I 

REI RETURN FROM EXCEPTION OR INTERRUPT I NR| 

REMQUE REMOVE FROM QUEUE I NR I 

RET RETURN FROM CALLED PROCEDURE I x I 

ROTL ROTATE LONG I X I 

RSB RETURN FROM SUBROUTINE I x I 

SBWC SUBTRACT WITH CARRY I [2] I 

SCANC SCAN FOR CHARACTER I x I 

SKPC SKIP CHARACTER I x I 

SOBGEQ SUBTRACT ONE AND BRANCH ON GREATER OR EQUAL 

SOBGTR SUBTRACT ONE AND BRANCH ON GREATER I X I 

SPANC SPAN CHARACTERS I x I 

SUBB2 SUBTRACT BYTE 2 OPERAND I X I 

SUBB3 SUBTRACT BYTE 3 OPERAND I x | 

SUBD2 SUBTRACT DOUBLE 2 OPERAND I [2] I 

SUBD3 SUBTRACT DOUBLE 3 OPERAND I [2] I 

SUBF2 SUBTRACT FLOATING 2 OPERAND I X I 

SUBF3 SUBTRACT FLOATING 3 OPERAND I X I 

SUBL2 SUBTRACT LONG 2 OPERAND I X I 



x 

X 
X 



I x I 
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C3 

22 

23 

A2 

A3 

07 

95 

73 

53 

D5 

B5 

FC 

8C 

8D 

CC 

CD 

AC 

AD 

08 

09 

OA 

57 

58 

59 

5A 

5B 

5C 

5D 

5E 

5F 

77 

FD 

FE 

FF 



SUBL3 


SUBTRACT LONG 


3 OPERAND | X 


I 


SUBN4 


SUBTRACT NUMERIC 4 


OPERAND | 


NR| 


SUBN6 


SUBTRACT NUMERIC 6 


OPERAND 1 


NR| 


SUBW2 


SUBTRACT WORD 


2 OPERAND | x 


1 


SUBW3 


SUBTRACT WORD 


3 OPERAND 1 X 


1 


SVPCTX 


SAVE PROCESS CONTEXT I NR I 




TSTB 


TEST BYTE | 


X 


1 






TSTD 


TEST DOUBLE 


1 


X I 






TSTF 


TEST FLOAT 


1 x 


1 






TSTL 


TEST LONG | 


X 


1 






TSTW 


TEST WORD | 


X 


1 






XFC 


EXTENDED FUNCTION < 


CALL 1 NR| 




XORB2 


EXCLUSIVE -OR BYTE 


2 OPERAND 


x 1 


XORB3 


EXCLUSIVE-OR BYTE 


3 OPERAND 


x I 


XORL2 


EXCLUSIVE -OR LONG 


2 OPERAND 


x I 


XOPL3 


EXCLUSIVE-OR LONG 


3 OPERAND 


x I 


XORW2 


EXCLUSIVE-OR WORD 


2 OPERAND 


x 1 


XORW3 


EXCLUSIVE-OR WORD 


3 OPERAND 


x 1 




* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 






* RESERVED 


TO 


CEC 


* 1 1 






* RESERVED 


TO 


DEC 


* 1 1 




ESCD 


* RESERVED 


TO 


DEC 


* 1 1 




ESCE 


* RESERVED 


TO 


DEC 


* 1 1 




ESCF 


* RESERVED 


TO 


DEC 


* 1 1 





CHAPTER 7 
CACHE-SB I-TB SUBSYSTEM 



7.1 MP BUS 

MD Bus transfers longword aligned data amongst the cache, SBI 
interface, data path, and instruction buffer. Signals are: 



BUS MD XX H 

BUS MD BYTE X PARITY H 

BUS MD BYTE X MASK H 



where XX runs 00 to 31 
where X runs to 3 
where X runs to 3 



TBMD 



TBMD 



D TO MD L 



MASK TO MD 



Parity is computed over each 8 data bits, such that if the 8 data bits 
are low, the parity bit will be high. The mask is not checked. Byte 
mask high means write on a write cycle, and means this byte is wanted 
on a read cycle. The data, parity, and mask are all long word 
aligned . 

The D TO MD signal directly drives the enables of the data and parity 
drivers on the data path. The MASK TO MD signal directly drives the 
enable of the mask driver on the data path. 



7.2 CS BUS 



subsystem 


uses 


6 CS bits: 






BUS 


CS 


42 


H 


UFS 


BUS 


CS 


47 


H 


UADS 


BUS 


CS 


46 


H 


UMCT3 


BUS 


CS 


45 


H 


UMCT2 


BUS 


CS 


44 


H 


UMCT1 


BUS 


CS 


43 


H 


UMCTO 



These bits will be received by 74S194 chips on the TBM board 
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7.3 V BUS 

This subsystem will meet the V bus spec. Available signals TBS. 



7.4 CLOCK BUS 



Clock signal loading is: 



7.5 ADDRESS BUS 

The address is received in three sections; 

VA REG < 8:2> H 

VA MUX <15:9> L 

VA MUX <31:16> L 

The first group of seven bits is the low bits of the CPU virtual 
address register, unbuffered. During a subsystem activity using a 
virtual or physical address in the VA register, these bits will be put 
on the PA bus, the subsystem internal physical address bus. During a 
microcode requested load of the Instruction Physical Address Register 
(IPA) the low seven bits will be copied from the VA bits. 

The next set of seven bits is the output of multiplexers. One set of 
data inputs is attached to the VA register, the other set is attached 
to the IA register. These multiplexer bits are constantly enabled. 

The upper sixteen bits are driven the same way as the middle seven, 
except that the enables of the multiplexers are driven by a CPU 
generated signal to provide zeros for compatibility mode. All 
microcode-specified memory operations use the address from the VA. 
The IA is used only for automatic reloading of the IPA. 



7.6 FROM IB 

A. IDPJ COUNT H means that the IPA should be incremented. 
Only present one cycle after the IB receives data. Not 
present during FLUSH. 

B. IDPJ FLUSH L means that the old IPA is no longer valid. 
Microcode should not do FLUSH and READ.V.NEWPC in the same 
state . 
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C. IRCH IB WRITE CHK H means that if the microcode does a 
READ.V. IBCHK the check should be for write access. This 
signal is clocked at the same time as the CS bits. 

D. IDPJ IB REQ H means that if the microcode allows an IBREAD, 
the IB would like to use it, or if miss data comes back, the 
IB would like to receive it. 



7.7 TO IB 

A. SBLR IB READ DATA L means that data for the IB is on te MD 
bus this microcycle. 

B. TBMX IB MISS L means that on the most recent load of the 
IPA, no entry was found in the translation buffer. 

C. TBMX IB ERR L means that either 

1. on the most recent load of the IPA, an entry was found in 
the TB but protection code was bad or 

2. on the most recent load of the IPA, a parity error 
occured or 

3. the SBI interface detected an error during a cycle being 
done for the IB which resulted in data never being 
delivered . 



7.8 FROM MICROSEQUENCER 

A. USCB ABORT CYCLE H means that the word coming from the 
control store should not be used because of a microtrap or 
ECO or console crock. 



7.9 TO MICROSEQUENCER 

A. SBLT STALL L means that the next microword should be 
temporarily prevented from executing. 

B. TBMD LAST REF CODE 1 H 
TBMD LAST REF CODE H 

are microbranch conditions. They are the output of a 
register clocked on any state which saves context (not 
inhibited by UMISC field). The codes are: 
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CODE 





1 

1 





1 
1 




means 



READ with RCHK 
READ with WCHK 
WRITE with WCHK 
INTLK READ 



TBMX BRANCH CODE 1 H 
TBMX BRANCH CODE H 

are microbranch conditions, 
register. 



They are the output of a 



CODE 





1 
1 





1 
1 




means 



WONDERFUL 

TBHIT and PROTECTION OK and MBIT ERROR 

TBMISS 

TBHIT and PROTECTION VIOLATION 



TBMB KERNEL MODE H 



is a microbranch condition. 



7.10 FROM TRAPS AND INTERRUPTS 

A. (TEMP) ISR CODE 1 H and H specify the level at which an 
interrupt summary read SBI transaction should be executed if 
the microcode orders one. Stable from before the 
microcommand until after it. 

B. (TEMP) CURRENT MODE 1 H and H are the current mode bits 
of the PSL used for checking protection for certain virtual 
references and for auto-refill of the IPA. Stable all during 
any of them. 

C. (TEMP) CSPAR ERR H 

D. (TEMP) CMODDADRS TRAP L 

E. (TEMP) PAGE TRAP H indicates data crossing page boundary. 



7.11 TO TRAPS AND INTERRUPTS 

A. Several signals which cause interrupts. 

1. SBLM CRD RDS INTR L requests an interrupt if the CPU 
receives a CRD or an RDS from the SBI. 

2. SBLM TIMO CNF INT L requests an interrupt if the CPU 
times out or receives an ERR confirmation on the SBI. 
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3. SBHE SBI REQ 7 R H 
SBHE SBI REQ 6 R H 
SBHE SBI REQ 5 R H 
SBHE SBI REQ 4 R H 

These are the SBI interrupt requests. 

4. SBHE SBI ALERT R H is the SBI ALERT signal. 

5. SBHK COMP INTR H requests an interrupt when the SBI 
silo comparator matches. 

6. SBHL FAULT INTR H requests an interrupt because of the 
assertion of FAULT on the SBI. 

B. Several signals which cause microtraps. 

1. SBLM TIMEOUT TRAP L requests a microtrap on CPU 
timeouts which prevent further progress. 

2. SBLP PAR ERR TRAP L requests a microtrap on CPU read 
cycles which encounter a cache parity error. 

3. SBLR RDS TRAP L requests microtrap if a CPU READ cycle 
receives an RDS from the SBI. 

4. TBMU PROT UTRAP L requests a microtrap if a translation 
for the CPU causes protection violation. 

5. TBMW TB PAR UTRAP L requests a microtrap on TB parity 
errors during translation for the CPU. 

6. TBMW MBIT UTRAP L requests a microtrap if a translation 
for the CPU doing a writecheck uses a TB entry with the 
MBIT not set. 

7. TBMW MISS UTRAP L requests a microtrap if a translation 
for the CPU does not find an entry in the TB. 

C. Several microtrap enable signals. 

1. TBMN PAGE EDGE H indicates that the data crossing page 
boundary microtrap is enabled and VAREG <8:3> are high. 

2. TBMW EN CMODDADRS H indicates that this type of memory 
cycle should enable the compatibility mode odd address 
trap. 

3. TBMW EN UNALIGN TRAP H indicates that this type of 
cycle should microtrap if the data is not aligned. 

D. TBMW SAVE CONTEXT H means that this type of memory cycle 
requires that certain context information be saved. This 
signal is overridden in the data path by certain UMISC field 
codes. 
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7.12 FROM DATA PATH - NONE 

7.13 TO DATA PATH 

A. SBLP MD to D L means that the D register should be loaded 
from the MD bus. 

B. TBMD D TO MD L turns on the MD bus drivers in the data 
path. 

C. TBMD MASK TO MD L turns on the MD bus mask drivers in the 
data path. 

D. TBMC ENABLE IA H is the input which switch the VAMUX. 

7.14 SELECTED INTERNAL SUBSYSTEM SIGNALS 

A. SBHM SET SBI CYCLE H means that the MD bus cycle coming up 
will be used by the SBI interface, usually to transfer data 
from a read miss or to invalidate a location in the cache 
that was written on the SBI. 

B. SBLK BUFFER FULL H means that the register in the SBI 
interface used to hold addresses for SBI cycles is full, 
because the previous write has not been acknowledged, the 
expected read data has not arrived, etc. 

C. SBLR VALID H is the input to the valid bit in the data 
cache tag . 

D. SBLR SET FORCE SBI L is the output of a circuit which will 
grab the first opportunity after a CPU write miss parity 
error to clear out the entry with the error. 

E. TBMU CANCEL L indicates to the SBI interface that the cycle 
requested by the microcode should not be completed this cycle 
because of some error condition known on TBM or because an 
auto-refill of te IPA is in progress. 



7.15 MICROBRANCHES 

(See "VAX 11/780 Microcode" for up to date information) 
A. BEN15 - LAST REFERENCE 
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This subsystem provides bits one and zero for this BEN. The 
code is: 



UPC 
1 


RETRY 


1 1 


I MICROORDER 


I 


1 8 


1 1 


1 14 


1 1 1 


1 6 


1 1 o 

1 


1 10 



B. BEN ID - TRANSLATION TEST 

This subsystem provides bits one and zero for this BEN. The 
code is given under microorders 0,2 below. 



7.16 MICROORDERS 

The available microorders are shown in the chart. Descriptions 
follow, indexed by the order number (decimal) . 

0,2 These are used to get the translation buffer's 
attention to load set of microbranch codes which can be 
tested in the next microinstruction. 

MSB LSB 
The code is 1 1 TBMISS 

1 PROTECTION VIOLATION. NOT 

TBMISS 
1 NOT PROT VIOLATION. NOT 

TBMISS. WCHK. MBIT 
NO PROBLEM 

6 This is the normal virtual write. This is retryable. 
Retry involves 

1. using the previous cycle type microbranch to find 
out which of the four retryable cycles was being 
done. 

2. sending the proper microorder again in combination 
with the proper saved context code in the 
miscellaneous field. 

5 This code does a virtual write without a protection 
check or modify bit check. It is used for cycles that 
are prechecked by microcode, such as writing page table 
entries. 



10 

11 

12 



14 
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7 This is the virtual interlock write. 

8 Normal virtual read. Retryable. 

9 Nocheck virtual read for page tables, etc. 

Retryable?^ "^ "^ ° heCk f ° r modif y in 9 accesses. 

Virtu ^ J read with Protection check read or write 
specified by the instruction buffer. The retry branch 
will indicate whether to retry as code 8 or 10. 

This cycle is used whenever the microcode wishes to 
reload the IPA, whether because of a macroprogram 
transfer of control or to restart instruction 
prefetching after loading the TB with a translation o? 
a previously missing page. It causes a virtual read 
cycle with data to the instruction buffer. All errors 
are handled with the IB error mechanism. 

Retryable"?^ 10014 reSd ' USed f ° r interlock instruction. 

13 nrf«fn k Vi K fc !! al interlock "ad. No known use at 
present, but may be needed if MBIT update is 
respecified as interlocked. F ls 

25 Physical Read, for LDPCTX etc. 
21 Physical Write, for STPCTX etc. 

29,23 present 1 Interlock Read and Write - N ° known use at 

Causes a Read Interrupt Summary transaction on the SBI. 
Causes an Extended Write on the SBI. The data written 

n MO? Pre ^ Ct f le Z. US ? d t0 Clear out double E <* errors 
m MOS. The location m cache will be invalidated. 

16,17 Asserts Hold and Unjam on the SBI. For use in the 
console UNJAM command sequence. 

Writes good parity non-valid data and tag in both 

ull^L !iV? e „ lndwc P° sition specified. No SBI cycle. 
Used on all index positions at power up. Also used by 
microdiagnostics. May also be used by certain error 



27 
20 



18 



19 



routines. 



Causes a write of the specified address and data, with 
good parity, marked valid, in the group specified by 

No SB? r cyci r e e f laCement ^^ ^ by "^diagnostics! 
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31,48-63 Allows initiation of read cycles by the instruction 
buffer while performing the ID bus operation specified. 
This code should be used in most places where an 
explicit memory operation is not required in order to 
allow the IB to acquire I stream bytes. Should not be 
used during IB FLUSH states. 

32-47 ID bus operation only, IB cycle initiation is blocked. 
This code should appear in all locations of error trap 
routines until the IB can be turned off to prevent 
multiple errors. 

1 NO OPERATION 



3,4,15,22,24,26,27,28,30 



RESERVED, UNPREDICTABLE, DO NOT USE 
EFFECT OF TRAPS 







READ 


WRITE 


TBMISS 






A 




A 


PROTECTION 






A 




A 


DATA CROSS PAGE 




A 




A 


DATA NOT ALIGNED 




N 




N 


WCHK.TBMBIT 






A 




A 


CM. ODD ADRS 






A 




A 


TB PARITY 






A 




A 


CACHE PARITY 






A 


No 


Trap 


TIMEOUT 






B 




B 


CRD 


*Not 


a Trap 




— 


URD (RDS) 






A* 




- 


CS PARITY 






A 




A 



A: No good read data 
memory not written 
cache not written 
cache sideeffected 
memory not sideeffected 

B: No good read data 

memory may be written 
cache may be written 
cache sideeffected 
memory may be sideeffected 

N: all normal effects 



memory sideeffected 



sideeffected includes 
changes in status bits 
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Memory Control Functions 



October 11, 1976 



A 

D MCT 

S 3210 



0000 

0001 

0010 

0011 

0100 

0101 

0110 

0111 

1000 
1001 
1010 
1011 

1100 
1101 
1110 

1111 

1 0000 
1 0001 
1 0010 
1 0011 

1 0100 
1 0101 
1 0110 
1 0111 

1 1000 
1 1001 
1 1010 
1 1011 

1 1100 1 

1 1101 

1 1110 

1 1111 

XXXX 1 

1 XXXX 1 



F 

u 

N 

c 

T 
N 



w 
w 

IW 

R 
R 
R 
R 

R 
IR 
IR 



W 



W 



W 
IB 



W 



HOLD 
UNJAM 
INVAL 
VAL 

EXTWR 
W 

IW 

R 
ISR 

IR 
R 



trap on 
O 
A T 
L B 
I U A 
G F D 
N M R 



D 
D 



NNNNNNYNN 
NNNNNNNNN 
NNNNNNYNN 



YN N-YNY 

YY**YYYNY 
YNY 



YY**NYYYY 
YN--N-YYY 
YY**YYYYY 
YYYYYYYYY 

NNNNNYNNN 
YN--N-YYY 
YY Y-YYY 



NNNNNNNNN 
NNNNNNNNN 
NNNNNNNNN 
NNNNNNNNN 

NNNNNNNNY 
NNNNNNNNY 

NNNNNNNNY 



NNNNNNNYY 
NNNNNNNNY 

NNNNNNNYY 

NNNNNNNNN 

NNNNNNNNN 
NNNNNNNNN 



Y = utrap on condition 

* « utrap on condition unless MSC/ 

SECOND. REF or RETRY. NO. TRAP 
N = do not utrap on condition 
- = hardware behaviour undefined. 

uncode must prevent condition 



TEST.RCHK 
MEM. NOP 
TEST.WCHK 



WRITE. V.NOCHK 
WRITE. V.WCHK 
LOCKWRITE.V.XCHK 

READ.V.RCHK 
READ. V.NOCHK 
READ. V.WCHK 
READ.V. IBCHK 

READ. V. NEW PC 
LOCKREAD. V.NOCHK 
LOCKREAD. V.WCHK 



SB I. HOLD 
SBI.HOLD+UNJAM 
INVALIDATE 
VALIDATE 

EXTWRITE.P 
WRITE. P 

LOCKWRITE.P 



READ.P 
READ. INT. SUM 

LOCKREAD. P 
ALLOW. IB. READ 

NO MEMORY OPERATION 
DEFAULT: ALLOW IB READ 



Abort Ref on Trap? AAA AAARA (A=any, R=read) 
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7.17 REGISTERS 



HEX ID ADRS 


REGISTER NAME 


10 


TRANSLATION BUFFER DATA REGISTER 


11 


NOT USED AT PRESENT 


12 


TB REGISTER 


13 


TB REGISTER 1 


14 to 17 


NOT USED BY THIS SUBSYSTEM 


18 


SILO DATA REGISTER 


19 


SB I ERROR REGISTER 


1A 


TIMEOUT ADDRESS REGISTER 


IB 


SB I FAULT-STATUS REGISTER 


1C 


1 SILO COMPARATOR REGISTER 


ID 


I MAINTENANCE REGISTER 


IE 


CACHE PARITY REGISTER 


IF 


NOT USED AT PRESENT 



10 TRANSLATION BUFFER DATA REGISTER 

This register is write only from the ID bus. It is used to 
write the translation buffer. The virtual address to be 
translated must be in VA, the PTE must be in D (the MBZ bits 
must be zero) . Which group is written is selected as 
follows: 

1. if the REPLACE BOTH bit is on in TB REGISTER 0, both 
groups are written. Otherwise, 

2. if one of the groups has a good entry for the address 
being translated, that entry will be updated. Otherwise, 

3. if one of the FORCE REPLACE bits in TB REGISTER is on, 
the selected group will be written. Otherwise, 

4. a randomly chosen group will be written. 

12 TB REGISTER 



bit# name and use 

MME - read/write bit. If not set, the TB parity, 
miss, protection, Mbit, and page boundary microtraps 
are disabled and any address which would normally be 
translated is used directly from the VA or VIBA as 
appropriate. 
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1-4 FORCE TB PARITY ERROR CODE - read/write. 

bit code force error is 

4 3 2 1 GROUP ADRS/DATA byte 




1 

10 DO 

11 Dl 

10 D2 

10 1 1 DO 

110 1 Dl 

111 1 D2 

10 A0 

10 1 Al 

10 10 A2 

10 11 1 A0 

110 1 Al 

110 1 1 A2 
1110 
1111 

NOT USED 



TBGO HIT - read only. This is the latched output of 
the group zero address checker. For diagnostics. 
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7 TBG1 HIT - as above for group 1 

8-15 LAST REF - read only. These bits contain the 
following information about the most recent non-NOP 
memory request by microcode. 

15 UPS 

14 UADS 

13 UMCT3 

12 UMCT2 

11 UMCT1 

10 UMCTO 

09 IB WCHK from the instruction buffer 

08 This cycle was delayed one cycle by 
an auto-reload of the IPA 

16 FORCE TBGO MISS - read/write. Causes the group 
address checker to say no match. 

17 FORCE TBG1 MISS - same for group 1. (NOTE: The force 
miss bits also disable TB parity checking on that 
group.) 

18,19 TB FORCE REPLACE CODE - read/write. 

Affects which group is written by the Translation 
Buffer Data Register as follows: 



19 18 





1 

1 
1 1 



result 



RANDOM GROUP 
GROUP 
GROUP 1 
DO NOT USE 



20 REPLACE BOTH - read/write. See Translation Buffer 
Data Register for effect. Normally used when clearing 
the TB. 

13 TB REGISTER 1 

bit# name and use 

0-3 IPA INFO - read only. These bits contain information 
about the most recent load of IPA as follows: 

bit 

AUTO LOAD - this load was automatic, not the 
result of READ.V.NEWPC 

1 PROTECT - there was a protection violation on 
this load (or miss) . 

2 PARITY - there was a parity error on this load. 

3 MISS - there was a TB miss on this load. 
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4 BAD IPA - read only. The information in IPA and IPA 
INFO is not useful. Set by counting across a page 
boundary or by FLUSH, cleared by loading the IPA. 

5 NOT USED 

6 LAST TB WRITE PULSE - read only. 

This bit indicates which group was most recently 
written. It is indeterminate if both groups were 
written. 

7 NOT USED 

8 CP TB PAR ERR - cleared by any write to this register. 
This bit indicates that the TB has requested a TB PAR 
ERR microtrap. 

9-20 TB PAR BITS - cleared by any write to this register. 
This group of bits will all be loaded if there is a TB 
parity error and either TB parity traps are enabled or 
the IPA is being loaded. Each bit gets a one if its 
corresponding checker detects an error, and a zero 
otherwise. 

bit group ADRS/DATA byte # 

9 A 

10 A 1 

11 A 2 

12 1 A 

13 1 A 1 

14 1 A 2 

15 D 

16 D 1 

17 D 2 

18 1 D 

19 1 D 1 

20 1 D 2 
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18 SILO DATA REGISTER 

Listed below are the bit assignments for the SBI Silo. 



BIT 



NAME 



31 


First entr 


y after 


30 


SBI 


INTLK 






29 


SBI 


ID4 






28 


SBI 


ID3 






27 


SBI 


ID2 






26 


SBI 


ID1 






25 


SBI 


IDO 






24 


SBI 


TAG 2 






23 


SBI 


TAG1 






22 


SBI 


TAGO 






21 


SBI 


M3 or 


SBI 


B31 


20 


SBI 


M2 or 


SBI 


B30 


19 


SBI 


Ml or 


SBI 


B29 


18 


SBI 


MO or 


SBI 


B28 


17 


SBI 


CNF1 






16 


SBI 


CNFO 






15 


SBI 


TR15 






14 


SBI 


TR14 






13 


SBI 


TR13 






12 


SBI 


TR12 






11 


SBI 


TR11 






10 


SBI 


TRIO 






9 


SBI 


TR09 






8 


SBI 


TR08 






7 


SBI 


TR07 






6 


SBI 


TR06 






5 


SBI 


TR05 






4 


SBI 


TR04 






3 


SBI 


TR03 






2 


SBI 


TR02 






1 


SBI 


TR01 









SBI 


TROO 







FAULT cleared 



NOTE: 
Silo bits 21-18 are 
written with SBI B31-B28 
when the SBI TAG FIELD 
specifies command address 
TAG. Otherwise, SBI M3-M0 
are written in these bit 
positions . 



The SBI Silo is a histo 
indicated SBI signals 
FAULT is not asserted on 
4 bit address counter i 
asserted, writes into th 
update of the counter is 
will increment only when 
while FAULT is asserted, 
location written has Bit 



ry register of the 
for the past 16 SBI 
the SBI, the silo is 

s updated every cycle. 

e silo are prevented, 
inhibited. The silo 
the silo is read ove 
When FAULT is deasse 
31=1. This register 



state of the 
cycles. While 
written and its 
When FAULT is 
and the normal 
address counter 
r the ID bus 
rted, the first 
is read only. 
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19 SBI ERROR REGISTER 



BIT # 



DESCRIPTION 



TYPE 



31-16 
15 
14 
13 
12 
11 
10 

9 

8 

7 

6 

5 

4 

3 

2 

1 





Enable 



1 




Not used 

RDS/CRD Interrupt 

CRD 

RDS 

CP timeout 

CP timeout status 

CP timeout status 

Not used 

CP SBI Error Confirmation 

IB RDS 

IB Timeout 

IB Timeout status 1 

IB Timeout status 

IB SBI Error Confirmation 

Multiple CP Error 

SBI Interface not busy 

Not used 



R 
RW 

RWCL 
RWCL 
RWCL 

R 

R 

R 

R 
RWCL 
RWCL 

R 

R 

R 

R 

R 

R 



Bit 15 & 14 



Bit 14, CRD (Corrected Read Data) sets whenever CRD is 
returned to the CPU. The AND condition of bit 14 and bit 15 
CRD/RDS interrupt enable causes an interrupt to be requested. 



Bit 13 



This bit set whenever RDS (Read Data Substitute) is returned 
to the CPU. The AND condition of this bit and bit 15 causes 
an interrupt to be requested. 

Bit 12 CP Timeout 



This bit will set any time there is a timeout for a CP 
requested cycle. While this bit is set an interrupt is 
requested. 

Bits 11-10 CP Timeout Status 



These bits described the type of timeout that has occurred. 
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BITS 
11 110 



DEVICE NO RESPONSE 

1 DEVICE WAS BUSY 

1 WAITING FOR READ DATA 
1 1 IMPOSSIBLE CODE 

If notification of timeout was by interrupt (not microtrap) 
and the code is 10 the cycle was a read, if codes 00 or 01 
the cycle was a write. If notification is by microtrap the 
type of cycle can be found in TB REG0 bits 15 to 8. 



Bit 8 



This bit sets whenever a CP requested cycle receives an error 
confirmation to a command address transfer. While this bit 
is set an interrupt will be requested. 



NOTE 

Writing a "1" in bit 12 clears bit positions 12-10 & 
8 & 2. 



Bit 7 



Bit 7, IB RDS will set any time for any RDS sent to the CPU 
while the SBI interface is fetching data for the instructuion 
buffer on the SBI. This bit is write one to clear. It is 
also cleared by flushing the instruction buffer. 

Bits 6-3 



These bits take on similar meaning to bits 12-10, & 8, except 
these bits set only for instruction buffer initiated 
requests. Writing a "1" in bit 6 clears bits 6-3. Bits 6-3 
clear with the FLUSHING of the instruction buffer. 

Notification is by IB error microbranch. The cycle type is 
always READ. 
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Bit 2 Multiple CP Error 



This bit will set when a second CP timeout or CP SBI error 
confirmation occurs with a previous CP timeout or CP SBI 
error confirmation set in the register. This bit is reset in 
the same manner as bits 12-10, & 8, by writing a "1" in bit 
12. 



Bit 1 



This bit is a "1" whenever the SBI interface is not busy 
doing something on the SBI. Bits 14 & 13 (CRD & RDS) should 
not be reset by microcode when this bit is "0" (SBI BUSY). 

1A TIMEOUT ADDRESS 

This register is a holding register for the Physical Address 
sent on the SBI. Its format is listed below: 

31 28 

I 1 PA <29:2> I 



Bit 31 = MODE 1 
30 = MODE 
29 = Protection Checked Reference 

PA = Physical Address 

When a timeout occurs on the SBI, this register will latch up 
with the physical address of the timeout. This register 
remains latched until the timeout error bit (located in the 
SBI error register, bit 12) is written as one. This register 
will not latch up when a timeout occurs while the SBI is 
getting data for the Instruction Buffer. This register is 
read only. 

Bits 31-29 provide the mode of the reference that resulted in 
the timeout. Bit 29 is for references not subject to 
hardware protection check. 

IB SBI FAULT - STATUS REGISTER 

Listed below are the bit assignments for the FAULT/STATUS 
register, also included is a description of the type of bit. 
R read only, RW read-write, and RWCL read write one to clear. 
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BIT # 



NAME 



TYPE 







• __ — 


31 


Parity FAULT 


R 


30 


Reserved 


R 


29 


Unexpected Read Data FAULT 


R 


28 


Reserved 


R 


27 


Multiple Xmitter FAULT 


R 


26 


Transmitter during FAULT cycle 


R 


25 


Spare 


RW 


24 


Spare 1 


RW 


23 


Reserved 


R 


22 


Reserved 


R 


21 


Reserved 


R 


20 


Spare 2 


RW 


19 


FAULT LATCH 


RWCL 


18 


FAULT Interrupt Enable 


RW 


17 


SBI FAULT Signal 


R 


16 


FAULT Silo Lock 


R 


15-00 


Not used 





Bits 31-26 are the FAULT bits defined in the SBI spec, 
25, 24 & 20 are spare read/write bits. 

Bits 19-17 



Bits 



Bit 19, FAULT latch sets on the leading edge of the SBI FAULT 
signal. While this bit is set, the CPU will assert FAULT on 
the SBI. This bit is write one to clear. When this bit is 
set and bit 18 (FAULT Interrupt Enable) =1 an interrupt will 
be requested. Bit 17, the SBI FAULT signal provides the 
ability to detect the FAULT signal being continuously 
asserted on the SBI. 

Bit 16 



The SBI Silo may lock due to two conditions (1) the SBI FAULT 
Signal or (2) the SBI Silo comparator finding a compare. If 
the SBI FAULT Signal was the reason for locking the Silo then 
Bit 16, FAULT Silo LOCK, will be set. If the comparator 
locked the silo, a bit in the comparator register will set. 
If both mechanisms occur simultaneously, both bits will set. 
Bit 16 will clear when a 1 is written into bit 19. The SBI 
FAULT signal must be deasserted for the silo to unlock. 



1C SILO COMPARATOR REGISTER 

The Silo Comparator allows the 
under another mechanism besides 
SBI. 



SBI Silo to become locked 
the assertion of FAULT on the 
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The Silo Comparator may lock the silo under 2 modes of 
operation. The first mode is unconditional lock. This 
allows the SBI Silo to become locked anywhere from to 15 
cycles after this register is written. The number is 
determined by the count field contained in this register. 
The count field is always set in l's complement, that is to 
lock unconditionally after one cycle, the number E would be 
set in the count field. The count field is incremented until 
it is equal to all l's. 

The second mode of operation is conditional lock. When 
certain conditions exist on the SBI, a compare signal will be 
generated. This compare signal is latched. The output of 
this latch allows the counter to be incremented. When the 
count fild is equal to all l's the SBI Silo will lock. 

In both cases the Silo will be unlocked by writing a number 
other than F in the count field. The SBI FAULT signal must 
be deasserted for the silo to unlock. 

The compare modes that are provided are: 

1. SBI ID = Maintenance ID 

2. SBI ID = Maintenance ID 

and 
SBI TAG = Comparator TAG 

3. SBI ID = Maintenance ID 

and 
SBI TAG = Comparator TAG 

and 
SBI B<31:28> or SBI M<3:0> = Comparator Command/Mask 
Field 

* When the comparator tag is equal to command/address the 
comparator command/mask field will be compared against 
B<31:28>, the command function, otherwise the compare will 
be against SBI M<3:0>. 

The Maintenance ID bits are located in the Maintenance 
register . 

The AND condition of Comp Silo lock and Silo Lock Interrupt 
Enable cause an interrupt to be requested. Listed below are 
the bit definitions for the comparator register. 
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BIT 



NAME 



TYPE 



31 


Comp Silo Lock 




R 


30 


Silo Lock Interrupt Enable 


RW 


29 


Lock Unconditional 


RW 


28 


Conditional lock codes 


RW 


27 


Conditional lock codes 


RW 


26 


Compare Command 


or Mask 3 


RW 


25 


Compare Command 


or Mask 2 


RW 


24 


Compare Command 


or Mask 1 


RW 


23 


Compare Command 


or Mask 


RW 


22 


Compare TAG 2 




RW 


21 


Compare TAG 1 




RW 


20 


Compare TAG 




RW 


19 


Count Field 3 




RW 


18 


Count Field 2 




RW 


17 


Count Field 1 




RW 


16 


Count Field 




RW 




Conditional Lock 


Codes 






BIT 








28 27 











No compare 






1 


ID only 






1 


ID. TAG 






1 1 


ID. TAG. cc 


itnma 



RW - Read Write 

RWCL - Read, Write one to clear 

* Any write to this register with bits 19 to 16 not all ones 
will clear this bit. 



ID MAINTENANCE REGISTER 



Listed below are the bit assignments for the maintenance 
register. 
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BIT 



NAME 



TYPE 



31 


Force P0 Reversal on SBI 


RW 


30 


Force Write SEQuence FAULT 


RW 


29 


Force Unexpected Read Data FAULT 


RW 


28 


Force Multiple Xmitter FAULT 


RW 


27 


Maintenance ID4 


RW 


26 


Maintenance ID3 


RW 


25 


Maintenance ID2 


RW 


24 


Maintenance ID1 


RW 


23 


Maintenance IDO 


RW 


22 


Force SBI Invalidate 


RW 


21 


Enable SBI Invalidate 


RW 


20 


Reverse Cache Parity Field 


RW 


19 


Reverse Cache Parity Field 


RW 


18 


Reverse Cache Parity Field 


RW 


17 


Reverse Cache Parity Field 


RW 


16 


Force Miss Group 


RW 


15 


Force Miss Group 1 


RW 


14 


Force Replacement Group 


RW 


13 


Force Replacement Group 1 


RW 


12 


Disable SBI cycles 


RW 


11 


Force Pi Reversal on SBI 


RW 


10 


Group 1 Match 


R 


9 


Group Match 


R 


8 


Force Timeout 


RW 


7-0 


Not Used 


R 



R - Read Only 
RW - Read Write 



REVERSE CACHE PARITY FIELD DEFINITION 
20 19 18 17 DESCRIPTION 















NOP 

















1 


Reverse 


Parity Groupl, 


Byte 


A, Address 








1 





Reverse 


Parity Groupl, 


Byte 


B, Address 








1 


1 


Reverse 


Parity Groupl, 


Byte 


C, Address 





1 








Reverse 


Parity GroupO, 


Byte 


A, Address 





1 





1 


Reverse 


Parity GroupO, 


Byte 


B, Address 





1 


1 





Reverse 


Parity GroupO, 


Byte 


C, Address 





1 


1 


1 


Unused 








1 











Reverse 


Parity Groupl, 


Byte 


3 Data 


1 








1 


Reverse 


Parity Groupl, 


Byte 


2 Data 


1 





1 





Reverse 


Parity Groupl, 


Byte 


1 Data 


1 





1 


1 


Reverse 


Parity Groupl, 


Byte 


Data 


1 


1 








Reverse 


Parity GroupO, 


Byte 


3 Data 


1 


1 





1 


Reverse 


Parity GroupO, 


Byte 


2 Data 


1 


1 


1 





Reverse 


Parity GroupO, 


Byte 


1 Data 


1 


1 


1 


1 


Reverse 


Parity GroupO, 


Byte 


Data 
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Bits 31 & 11 



While these bits are set, the appropriate parity generator in 
the SBI interface is reversed. The SBI interface must be 
forced to transmit to force this FAULT on the SBI. 

Bit 30 



While this bit is set, all writes done by the SBI interface 
will cause a write sequence FAULT. This is done by changing 
the WRITE DATA TAG to the TAG reserved for diagnostic use. 

Bit 29 



While this bit is set, the SBI interface will transmit TAG=0 
(read data), ID=Maintenance ID, DATA=undef ined , parity ok. 
This will cause unexpected read data FAULT in the NEXUS 
selected by the maintenance ID. 

Bit 28 



While this bit is set, multiple transmitter FAULT can be 
forced in any NEXUS. For NEXUS other than the CPU, the error 
is forced by reading the NEXUS configuration register. After 
the command address transfer specifying read, the CPU 
transmits the conditions specified under bit 29, except the 
TAG which is transmitted as 111, the reserved TAG. When the 
NEXUS returns the read data, with ID=CPU ID, that NEXUS will 
have a multiple transmitter FAULT (provided that maintenance 
ID was set to a value that would cause an ID mismatch to 
occur) . 

The CPU has this error forced by doing a write command. The 
CPU ID will be transmitted for the command address transfer. 
The maintenance ID will be transmitted with the write data. 
When the received ID is compared against the CPU ID, after 
the write data transmission, a mismatch will occur resulting 
in a multiple xmitter FAULT. 

Bits 21-23 



These are the maintenance ID bits. They are used for forcing 
unexpected read data FAULTS, forcing multiple transmitter 
FAULTS and as a compare field for the Silo Comparator. 

Bit 22 



Setting this bit forces writes done by the CPU on the SBI to 
become a write invalidate to the CACHE. 
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Bit 21 



When this bit is set write invalidates from the SBI are 
allowed. When this bit is "0" write invalidates from the SBI 
are ignored. This bit must be on for normal system 
operation. 

Bit 17-20 



These bits are the reverse CACHE Parity Field. Setting this 
field to a specific code causes the indicated byte to have 
its parity bit continously asserted. To force the error trap 
the appropriate CACHE operation should be initiated. 

Bits 16-15 

These bits provide a method of forcing misses in the CACHE. 
Misses are not forced for write operations. This prevents 
the CACHE data from becoming stale. The bits have the 
following meaning. 

BIT FUNCTION 



16 15 

No misses forced 

1 Force miss on Group 1 

1 Force miss on Group 

1 1 Force miss on Group 1 and Group 

Misses are forced only for read requests for the Data Path or 
instruction buffer. Misses are not forced for write or 
invalidate operations. Setting these bits will also cause 
parity errors to be ignored. 

Bits 14-13 



Normally, replacement in the CACHE is random. These bits 
provide for overriding the random bit. 



BIT CACHE REPLACEMENT 



14 13 

Random 

1 Group 1 always 

1 Group always 
1 1 Undefined 
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Bit 12 



While this bit is set, no SBI cycles will be started. For 
read operations with a CACHE miss, the data in the D register 
will be unpredictable. 

Bits 10-9 



These two bits are clocked every time there is a read request 
for the Data Path or the instruction buffer that results in 
(1) a CACHE Hit or (2) an SBI cycle started due to a CACHE 
Miss. (approximate) 

Bit 8 



This bit provides a mechanism for forcing timeouts on a read 
operation. This is done by loading the timeout counter with 
'FF' after the read command has been accepted. 

IE CACHE PARITY ERROR REG 

The bit definitions for this register are listed below: 

BIT # DESCRIPTION TYPE 



31-16 Not used R 

15 Any Parity Error RWCL 

14 CP Parity Error R 

13 Parity OK CDM Groupl Byte R 

12 Parity OK CDM Groupl Byte 1 R 

11 Parity OK CDM Groupl Byte 2 R 

10 Parity OK CDM Groupl Byte 3 R 

9 Parity OK CDM GroupO Byte R 

8 Parity OK CDM GroupO Byte 1 R 

7 Parity OK CDM GroupO Byte 2 R 

6 Parity OK CDM GroupO Byte 3 R 

5 Parity OK CAM GroupO Byte R 

4 Parity OK CAM GroupO Byte 1 R 

3 Parity OK CAM GroupO Byte 2 R 

2 Parity OK CAM Groupl Byte R 

1 Parity OK CAM Groupl Byte 1 R 

Parity OK CAM Groupl Byte 2 R 



Bit 15 



This bit will set any time a CACHE parity error is detected 
on a IB or CP read operation. Writing a "1" to this bit 
position forces 0's in all positions of the register (same 
state as on power up) . 
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Bit 14 



When bit 15 is set, this bit signifies whether the CACHE 
parity error was for the CP, Bit 14=1, or the instruction 
buffer, bit 14=0. 

Bits 13-0 



When bit 15 is set, these bits identify the CACHE bytes which 
did not have an error. 



NOTE 

This register will clear if it is holding a parity 
error for the instruction buffer and the instruction 
buffer is flushed. 



ID REGISTERS "ON" TBM BOARD 



ADRS 




HEX 




10 TB 


DATA 


WRITE 


ONLY 



31 



30 



27 26 



25 



21 20 



V 
A 
L 
I 
D 



PROTECTION 
CODE 



M 



MUST BE ZERO 



PHYSICAL ADDRESS PAGE FRAME NUMBER 



SEE VAX 11/780 ARCHITECTURE HANDBOOK 



12 TB REG 



31 




21 20 


19 18 


17 16 


15 


14 


13 


12 11 10 9 


8 


7 6 


5 


4 1 










1 R 
1 E B 
1 P 
1 L T 
1 A H 

1 c 

1 E 


1 FORCE TB 
1 REPLACE 
1 CODE 
1 Gl I GO 
1 1 
1 1 
1 1 


FORCE TB 

MISS 
Gl | GO 
1 1 

1 

1 1 

1 


U 
F 
S 


U 
A 
D 
S 


LAST 
1 

1 u 

1 M 

1 c 

1 T 

1 3 


REFERENCE WAS: 

II II 
1 U | U | U | B 
M | M | M | W 
C I C | C I C 
T | T | T | H 
2 I 1 | | K 


1 

1 A 
1 R 
1 

1 
1 


1 1 
1 1 
1 TBI TB 
1 Gil GO 
IHITIHIT 
1 1 
1 1 
1 1 





FORCE TB 

PARITY ERROR 

CODE 


M | 
M I 
E I 



SEE CACHE SUBSYSTEM SPEC 

"NORMAL" USE > 

INIT > 


















X 


X 


X 


X 


X 


X 


X 


X 


X 


X 














R/W 

1 (ON) 

















X 


X 


X 


X 


X 


X 


X 


X 


X 


X 


















n 
> 
o 

SB 

w 
I 

en 
w 

I 

w 

CO 

c 

CD 
CO 
K 
CO 
*3 
W 
3 



31 



21 20 



9 8 



13 TB REG 1 













TB 


PARITY 


ERROR BITS 








1 CP| 




ILAST 




1 




I PA INFO I 




GROUP — > 


1 


1 


1 





| 


1 1 1 1 1 1 


1 


1 


1 


1 TBI 





I TB 





BAD| 


M 


IP E |P E|A L| 


1 o 


A/D — > 


D 


D 


D 


D 


D | D 


1 A | A | A 


A 


A 


A 


IPARI 




1 WP 




IPA| 


I 


|A R|R R|U 01 




BYTE — > 


2 


1 





2 


1 1 


1 2 | 1 | 

1 1 1 
1 1 1 
1 1 1 


1 2 


1 1 


1 


1 ERR I 

1 1 
1 1 
1 1 




1 
1 
1 
1 




1 
1 
1 
1 


S 
S 


|R RIO RlT A| 
U IT |0 D| 
IT | | | 
IY I | I 



SEE CACHE SUBSYSTEM SPEC 



Q> 
(T> 

i 

-J 



READ ONLY EXCEPT ANY WRITE TO THIS REGISTER CLEARS 

— > I THESE BITS | 

INIT > 000O0O00OO0O00X 011100 

ID REGISTERS ON SBI BOARD 

31 30 29 25 24 22 21 18 17 16 15 

, , ! , , "- - ~ 

I AFTER | SBI | | SBI I SBI M3-M0 OR I SBI | | 

18 SBI SILO | FAULT I INTLK | SBI ID | TAG I B31 - B28 | CNF1-0 I SBI TR<15:00> I 
INIT UNPREDICTABLE I I I I I | | | 

31 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 

19 SBI | IRDSIC |R | III I CP| IB| IB | IB| IB | IB| | | | 
ERROR | NOT USED, ZERO I INT i R | D I CP | TO I TO I ZERO | ERR |RDS | TO | TO I TO I ERR IMULT |NOT | ZERO I 

I I EN| D| S| TO IST1IST0I |CNF| | |ST1 I ST0|CNF|ERR | BSY I I 

INIT = 0< > 10 

31 30 29 28 27 

I I I I I " "" """ ~"T 

1A TIMEOUT | MODE | MODE | PROT | | PHYSICAL ADDRESS<29: 2> I 

ADDRESS | 1 | | CHK I I | 

I I I I I I 

INIT UNPREDICTABLE 

31 30 29 28 27 26 25 19 18 17 16 15 

III II I I I I I I I I IFLTI |FLT | I 

IB FAULT/ |PTY| | UNEX | I MLTlXMITl | | I I I | FLT | INT | FLT |SILO I NOT USED, ZERO I 

STATUS |FLT| | RD | |XMIT| FLT | I I I I I I LTH I EN|SIG|LCK | I 

CLEAR ON INIT 



O 

> 
O 

EC 
M 

I 

cn 

03 
M 

I 

m 

c 

00 

w 

K 
CO 
H 

w 

3 



T3 
Ql 

(T> 

-J 
I 
to 

CO 



> 
o 

33 

a 
I 

CO 

CO 
M 

I 

31 30 29 28 27 26 23 22 20 19 16 15 w 

I CMP I I I COND I I I I I c 

1C COMPARATOR I SILO I INT I LOCK I LOCK | COMPARE ICOMP I COUNT I NOT USED, ZERO I CO 

I LOCK I EN IUNCONDI CODES I COM OR MASK I TAG I FIELD | I " 

CO 

•-a 

CLEAR ON IN IT § 

ID SBI MAINTENANCE 

31 30 29 28 27 23 22 21 20 17 16 15 14 13 12 11 10 9 8 7 

I REV|WRT| UN|MULT| I FORCE | EN | REV | FORCE I FORCE I FORCE I FORCE |DIS I REVlGRP |GRP |FORCE| I 

|P<0>|SEQ|EXP|XMIT| MAINT ID I SBI |SBI| CACHE PARI MISSl MISS I REP | REP |SBI|P<1>| 1 I | TO I NOT USED, ZERO I 
| |FLT| RD| | | INV IINVI I GRO | GR1 I GRO I GR1 I CYC I |MTCH|MTCH| I I 

CLEAR ON INIT 

31 16 15 14 13 

I | ANY I I I 

IE CACHE PARITY | NOT USED, ZERO I PTY I CP I PARITY OK FIELD I 

| I ERR I ERR I I 

CLEAR ON INIT 



•V 
0) 

fl> 

-J 

I 
to 
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7.18 GENERAL DESCRIPTION 

The Translation Buffer is 64 entries deep, two way associative. 
Virtual address bits 14 thru 9 are used as the index. This cache 
translates addresses in the VA register for microcode requested 
cycles, and translates addresses in the VIBA for automatic reloads of 
the IPA (Instruction Physical Address) register. This cache is 
bypassed for physical address references or when MME bit is off. 

The IPA keeps a pretranslated copy of the VIBA (Virtual Instruction 
Buffer Lookahead Address) to prevent the waste of repeated 
translation. The IPA and VIBA are counted in step. When the IPA 
counts accross a page boundary, prefetching is prevented until the IPA 
is automatically reloaded. The reload is controlled by hardware 
sequencing logic which will start the reload during any ALLOW. IB. READ 
microcycle. The reload is completed in the following cycle. If this 
cycle requested a memory operation it is stalled for 200 nanoseconds. 
Once the reload is completed, prefetching will start again, unless a 
miss or other error occurred during the reload. In this case the IB 
will eventually run out of data and notify the microcode of the error. 
Note that the reload sequence occurs even if MME is not on. 

The IPA can be loaded by microcode using the READ.V.NEWPC command. 
This is normally used when macrocode transfer of control occurs or 
when prefetching has stopped because of a translation miss and a new 
entry has been put in the TB. 

When a memory cycle is to be performed, the appropriate address (VA, 
IPA, or translation) is selected by the PAMUX onto the PA BUS. The 
data cache uses addresses on the PA BUS to search for data. 

The Data Cache is two-way associative. Each group contains 1024 
long-word entries. One address is stored for each two long-words (one 
quad-word). If a hit occurs, the appropriate long-word is transmitted 
on the MD BUS. If a miss occurs, the quad-word containing the 
requested data is brought in from memory and placed in the cache (the 
appropriate long-word is also transmitted to the requestor) . If the 
requested data is in I/O space instead of memory, only the appropriate 
long-word is read in, and it is not placed in the cache. 

The replacement strategy is RANDOM. This means that when a new 
quad-word block is brought into the cache, it is placed in one group 
or the other as a random selection, not according to the previous 
entry's age or other characteristic. 

The write strategy is write-thru, and not-write-allocate. Write-thru 
means that any write data transmitted from the CPU to the cache is 
immediately passed along to main memory. Not-write-allocate means 
that if the CPU transmits write data and a corresponding entry is not 
present in the cache the data is simply sent to memory with no new 
entry being made in the cache. 
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t 7.19 MICROCODING SUGGESTIONS 

A. To prevent auto-reloading of the IPA: 

X ' ^p'Ts ^rus^l 1 "^ St8rt lf ^ ALL °W.IB.READ (either 

2. If a page boundary has not been crossed already, it will 
not be crossed if the IB cannot count the IPA, which will 
not happen if the IB is stopped. 

3. A FLUSH of the IB will stop any auto-reload. 

B ' happen."" 6 ^ 16 "^ **" VIBA anytime that an auto-reload may 

C After a new entry is placed in the TB as a result of an tr 
miss, a READ.V.NEWPC is required to load the ?PA. 

D. Do not do FLUSH and READ.V.NEWPC in the same microstate. 

E * oniric an ? °- tMS sub »y«te«'B ID registers while a memory 
operation is m progress is strongly unrecommended . * 

F. The microcommands in this subsystem's hardware error 
microtraps should contain NOP until the IB can be turned off 

it is saved, to prevent loss of information. 



G. 



Cache error registers should be read out, saved, and cleared 
before doing any more memory references on errors. cleared 

H. Remember that FLUSH clears out certain IB error information. 

I. Remember that all microcommands for explicit memorv 
operations use the address in VA, including REAd'v.NEWPC? * 

J * mLrostatf^Do nt h* r T stei : in a mem °^ reference 
microstate. Do not change D register in a write micrn^sfo 

field' of y r^/ eStriC 5 i0nS ° n the D -gis? e r cLck Cr 2on?roi 
field of read microstates, see the data path spec. 

K. When using the INVALIDATE microcommand to clear the cache 

^ r 9 :- ^- 00 ^ 6 ^- B ° th grou P s are beared at once. All 
1024 combinations of address bits 11 thru 2 must be cleared! 

L " an" zero ri wLd th % TB ;, Se ^ the ReplaCe Both bit and send an 
an zero word to the TB. For a complete clear usp all fid 
combinations of address bits 14 thru 9. Ciear ' use a11 64 
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M. The MBZ bits in entries for the TB must be zero. 

N. Many of the force error bits in this subsystem are meant for 
microdiagnostics only and will hang the system if set by 
macrocode. 

0. Remember that finding one error bit set somewhere does not 
mean there are no other errors. Due to the independent 
asynchronous operation of the IB, many interesting error 
combinations are possible. 

P. The system will not run if misses are being forced on both 
groups of the TB. It will run with misses forced on both 
groups of the data cache. 

Q. Make sure that an autoreload is not in progress and does not 
start when reading or writing any TB ID register. 

R. Do not reset the CRD or RDS bits if an SBI cycle is still in 
progress for the IB. 

S. Do not read silo data when the silo is not locked. 

T. Do not change the current mode bits in the PSL while any 
memory reference is being requested. 

U. Do not request a READ.V.NEWPC unless prefetching is stopped. 

V. Do not reset timeout bits if an SBI cycle is still in 
progress. 

W. Because of the UNIBUS DATIP problem, the first WRITE. V 
following a READ.V with write check must be the corresponding 
write unless the read is aborted. 

X. Do not set or clear MME without preventing AUTO-RELOAD. 



CHAPTER 8 
VAX 11/780 CONSOLE SUBSYSTEM 



The VAX 11/780 console subsystem consists of four major 
components: an LSI-11 microprocessor (KD-11F) , which includes 4K of 
RAM; a single floppy disk and controller; a terminal and two serial 
interfaces, one for remote capability; and a CPU/console interface 
(CIB) which includes 2K or 4K of ROM. 

The console system provides three major functions: 

1. Traditional "lights and switches" functions such as examine, 
deposit, halt, start, single instruction, etc. 

2. Diagnostic and maintenance functions, including the 
capability to load diagnostic microcode into WCS, control 
execution, and monitor results; control single step clock 
functions; and examine key system points via a serial 
diagnostic bus. 

3. Materialize the terminal I/O registers in the processor 
register space. In the VAX 11/780 system, these register are 
on the ID bus and are in reality a mechanism by which VAX 
11/780 microcode and LSI-11 software can communicate. 
Therefore, this same port is also used for floppy I/O 
transfers and any other (software defined) communication. 
(See Appendix) 

The functions in items 1 and 2 are implemented at the user level by a 
set of keyboard commands and responses at the terminal. The LSI-11 in 
turn controls the VAX 11/780 CPU through a set of control/status and 
data registers in the Q-bus I/O space, which connect to the ID bus, 
the V-bus (the serial diagnostic bus) and many internal points in the 
CPU. 
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8.1 THE CONSOLE/CPU INTERFACE 



The Console 
contains a 
all the nece 
needed. In 
is provided 
of course, 
at any micro 
service mi 
accompl ished 
Memory Mappi 



Interface Board (CIB) is a board in the CPU backplane. It 

Q-bus interface, an ID-bus interface and termination, and 

ssary hardware to implement the various control functions 

addition a Read-only memory of either 2K X 16 or 4K X 16 

for the "core" of the console LSI-11 software. There is, 

a method by which the LSI-11 can force microcode execution 

address. This mechanism is used to call various console 

croroutines. Also, physical memory references are 

by using the virtual reference mechanism, but with the 

ng Enable (MME) bit turned off. 



FUNCTIONS IMPLEMENTED BY CIB 

FUNCTIONS IMPLEMENTED BY MICROROUTINES 

Virtual examine byte, word, longword 

Virtual deposit byte, word, longword 

Examine general registers 

Deposit general registers 

Examine processor register 

Deposit processor register 

Continue 

Initialize TB, cache, etc. (result of CPU initialize signal) 

Quad clear 

SBI unjam 

FUNCTIONS IMPLEMENTED BY HARDWARE 



Stop clock 

Start clock 

Step one time state 
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Step one SBI cycle (stops in CPU TO) 

Select one of four clock frequencies 

Assert CPU initialization signal 

Interrupt VAX CPU (terminal registers) 

Halt at end of current instruction 

Step single instruction 

Stop clock upon microbreak match (in CPTO of match state) 

Force UPC<12> to WCS on microtrap 

Force NOP on selected ROM fields 

Clock VBUS 

Assert VBUS loopback bit 

Load VBUS registers 

Read VBUS serial channels 

Sense positions of auto-restart, boot, lock, and remote switches 

Time-out off VAX 11/780 interrupt strobe signal, use to assert 
run light 

Provide a write-only register on the ID bus (FM ID) (as a 
responder) 

Provide a read-only register on the ID bus (TO ID) (as a 
responder) 

Write to any ID bus address (requires console control and clock 
running) 

Read any ID bus address (when clock is stopped or running) 

Synchronize use of FM ID and TO ID via ready & done bits 

Read clock states 
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Sense assertion of console acknowledge (reply to halt request) 

Sense when system clock is stopped 

Maintenance return (forced jump to UPC off top of microstack) 

Turn floppy disk power on or off 

Read ID address and direction lines (clock stopped only) 

Materialize JMP into ROM at 173000 and 173002 

The capability to read/write at any ID address permits register 
accesses to implement the following functions (and others) . 

Push microstack 
Pop microstack 
Write microbreak 
Read microbreak 
Read WCS address 
Write WCS address 
Write WCS data 
Read WCS status 
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8.2 ID BUS REGISTERS ON CIB 

All of these registers except the SYS. ID register are essentially 
dual-ported between the ID bus (for VAX 11/780 access) and the Q-bus 
(for LSI-11 access). 

This section describes the appearance of the ID bus registers on the 
VAX 11/780 side of the interface, i.e., as seen by VAX 11/780 
microcode. The appearance of these registers to the LSI-11 is 
described in section 4.0. 

The CIB as 5 ID bus addresses assigned, from 3(16) to 7(16). 



I I 

03 SYS. ID R/O | SYS ID<31:0> | 

I I 



I I RX I RX I 

04 RXCS R/W | | DNE I IE | 



05 TO ID(RXDB) R/0 I TO ID<31:0> 



I I TX | TX | | 

06 TXCS R/W | I RDY | IE | | 



07 FM ID(TXDB) W/0 I PM ID<31:0> 



ID registers as seen by VAX 11/780 microcode 

Figure 8-2 
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ID03 - 



System Identification - 

SYS ID is a read only register used to materialize the system 
ID register in the procreg space. (Exact format is TBS) . 
The 32 bits come out to pins for backpanel switches. Pull-up 
resistors are provided on the board. 



ID04 



Receiver Control/Status register 

The RXCS is used to materialize the 

receiver data buffer in the procreg 

data transfers from the LSI-11 to microcode 

register. 



RXCS for the terminal 

space, and to syncronize 

through the TO ID 



RXCS<7> - Receiver Done (RX DNE) - R/O 

Set by the LSI-11 to indicate to microcode that valid 

data is available in the FM ID register. Cleared 

automatically by the hardware when the TO ID register 

is read on the ID bus. Cleared by system 

initialization. 

RXCS<6> - Receiver Interrupt Enable (RXIE) - R/W 
When set, enables an interrupt at IPL 13 and vector CC 
to the VAX 11/780 CPU. (See Interrupts and Exceptions 
specification) , each time RX DNE makes a transition 
from to 1 . Only one interrupt for each transition is 
generated. If RX DNE is already set and RXIE goes from 
a to a 1, the interrupt will also occur. Cleared by 
system initialize. 

ID05 - To ID register (TO ID) - R/O 

(Note: "To" and "Prom" are with respect to the LSI-11). 

Contains up to 32 bits of data from the LSI-11, to be read by 
microcode. Valid only when RX DNE is set. Reading TO ID on 
the ID bus automatically clears RX DNE. 

ID06 - Transmit Control/Status (TXCS) - R/W 

The TXCS is used to materialize the TXCS for the terminal 
transmit data buffer (FM ID) in the space, and to synchronize 
data transfers from microcode to the LSI-11 through the FM ID 
register. 

TXCS<7> - Transmitter Ready (TX RDY) - R/O 
Set by the LSI-11 to indicate it is ready to accept 
another character in the TXDB (FM ID) register. 
Cleared automatically by a write to the FM ID on the ID 
bus; cleared by system initialize. 

TXCS<6> - Transmit Interrupt Enable (TXIE) - R/W 
When set, enables an interrupt at IPL 13 and vector C4 
to the VAX 11/780 CPU, each time TX RDY goes from a 
to a 1. Only one interrupt occurs for each 0-1 
transition. If TX RDY is already set and TXIE makes a 
0-1 transition, the interrupt will also occur. Cleared 
by system initialize. 
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ID07 - From ID register (FM ID) - W/O 

Loaded by microcode with up to 32 bits of data to be passed 
to the LSI-11. Should be loaded only when TX RDY is a "one". 
Writing to FM ID on the ID bus will automatically clear 
TX RDY. 



Use of the TO ID and FM ID registers 



Under normal circumstances, when the VAX 11/780 CPU is running, only 
the 16 low bits of the FM ID and TO ID are used, and all references to 
the RXCS, TO ID, TXCS, and FM ID are the result of microcode 
interpretation of MFPR's and MTPR's. For MTPR and MFPR references to 
TO ID and FM ID, microcode does not test the state of the 
corresponding READY or DONE bits prior to referencing the data 
register; to do this would affect interrupt latency time. It is 
assumed under these circumstances that macro level instructions have 
already tested the synchronizing bits. 

When the CPU is halted (i.e., in the console wait loop) microcode uses 
the same two registers (this time all 32 bits) to pass parameters 
to/from LSI-11 software. For any references other than MFPR's and 
MTPR's, it is microcode's responsibility to test the appropriate 
synchronizing bit prior to referencing the register. The bit must be 
a "one" before the read or write can take place. 

Since the LSI-11 has no knowledge of the state of the TXIE and RXIE 
bits, a mechanism is provided to disable these interrupts to the VAX 
11/780 and inhibit any change in the state of the "interrupt pending" 
flops while the console is in control and using the TO ID and FM ID 
registers for examines, etc. 

It should also be understood that the TXCS and RXCS bits are totally 

divorced from the corresponding bits in the DLV-11. In program I/O 

mode, the LSI-11 simply passes data from/to the CIB, to/from the 
DLV-11. 



8.3 THE Q-BUS REGISTERS 

This section describes the functions and appearance of the registers 
on the Q-bus which the LSI-11 uses to control and monitor the CPU and 
handle data transfers and control of the ID bus. 

For the breadboard, this block of addresses starts at location 
173000(8). However, a block of 16 addresses has been assigned to the 
CIB, starting at 163000(8). A wire jumper will permit selecting which 
address group is used. 



1X3000 ROM0 



1X3002 R0M1 



1X3004 SPARE 



1X3006 ID DATA LO 



1X3010 ID DATA HI 



1X3012 SPARE 



ROMO DATA<15:0> 



I R/O 



15 



ROM1 DATA<15:0> 



R/O 



15 



SPARE 



I TIME OUT 



15 



ID DATA<15:0> 



I 

I R/O 

I 



15 



ID DATA<31:16> 



R/O 
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SPARE 



TIME OUT 
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1X3014 RX DONE 



1X3016 TX READY 



I 

I RX 

I DNE 

I 



15 



8 7 6 
I I 



I TX 
I RDY 



I 



15 



8 7 6 



Q-bus Registers, low 8. X=6 or 7 
Figure 8-3 



I R/W 
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I R/W 
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1X3020 TO ID LO 



1X3022 TO ID H 



1X3024 FM ID LO 



1X3026 FM ID HI 



1 1 

1 TO ID<15:0> | 
1 1 


15 







1 1 
1 TO ID<31:16> | 

1 1 


15 







1 1 
1 FM ID<15:0> | 

1 1 


15 







1 1 
1 FM ID<31:16> | 

1 1 



R/W 



I R/W 



R/0 



R/0 



•tJ 
Q» 

(D 

oo 
I 



15 



1X3030 ID C/S 



1X3032 MCR 



I ID | REC | REC | ID | ID | 

I CYCLE | WRITE | ID ADDRS<5:0> | MAINT | WRITE I 
III III 



I 



ID ADDRS<5:0> | R/W 
I 
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I l\ l\ I l\ I I TRAP I STAR 

I HLT | \ | \ | CPU | \ | MAINT | TO I INTR 

I REQ I \ | \ | RESET I \ I RTN | WCS | DISAB 

I I \l \l I \l ENABLE | | 



I I 1 I I I I I 

ROM | SOMM | CLK | FREQ | PREQ | STS | SBC | PRO- 1 R/W 

NOP I | STPD I <1> | <0> | | | CEED I 

I I I I I I I I 



15 14 13 
1X3034 MCS 



12 



11 10 



8 



|\ |\ |\ I FLPY I |\ ICNSLI | HALT I RDY | DNE | \ |\ | AUTO | RE- | | 

I \ I \ I \ I OFF | BOOT | \ |CMND| RUN | STATE I IE | IE | \ | \ | RST. | MOTE | LOCK | R/W 

I \ I \ I \ I I I \ IMODEI | | | I \ I \ I | | | 



15 14 13 12 11 10 9 8 



1X3036 V-BUS 



VBUS SER CHNL<7:0> 



I CPT | CPT | CPT | CPT 
I | 1 | 2 | 3 



15 



8 7 



6 



IV I V | V | 

I SLFTST I LOAD | CLK | R/W 



Q-bus Registers, high 8. X=6 or 7 
Figure 8-4 
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Control/Data registers (refer to Figures 8-3 and 8-4) 

00. ROM0 - Read only memory - R/O 
02. ROM1 - Read only memory 1 - R/O 

These two registers, at 173000(8) and 173002(8), will contain a 
JMP X instruction to the LSI-11, where X is the starting location 
of the power-up code in the ROM. These two words are physically 
ROM locations and 2, which therefore also appear at addresses 
140000 and 140002. The LSI-11 will be configured to fetch at 
173000 (a jumper option) upon power up, to execute the jump into 
the power-up code. 



04. 


spare - Unused, will time-out if referenced 


06. 


ID bus data<15:0> - ID DATA LO - R/O 


10. 


ID bus data<31:15> - ID DATA HI - R/O 



These two registers provide visibility directly to the received 
data on the ID bus, and are valid only when the clock is stopped. 

12. Spare - Unused, will time-out if referenced. 
14: Receiver Done - RX DONE - R/W 

RX DONE<7> is the "backside" of the RX DNE bit in the RXCS 
register. It is set by the LSI-11 to indicate to the microcode 
that valid data has been placed in the TO ID register. It is 
cleared automatically by a read reference to TO ID on the ID bus, 
or by system initialize. The 1 — >0 transition of RX DNE will 
interrupt the LSI-11, if enabled. 

15: Transmitter Ready - TX READY - R/W 

TX READY<7> is the "backside" of the TX RDY bit in the TXCS 
register on the ID bus. When set by the LSI-11 it indicates to 
VAX 11/780 microcode that the LSI-11 is ready to accept another 
longword in the FM ID register. It is cleared automatically by a 
write reference to FM ID on the ID bus, or by system initialize. 
The 1— >0 transition of TX RDY will interrupt the LSI-11, if 
enabled. 



VAX 11/780 CONSOLE SUBSYSTEM Page 8-13 

NOTE 

1) The LSI-11 has no visibility to the 
VAX 11/780 interrupt enables, TXIE and 
RXIE. 

2) If the clock is running, clocking RX 
DNE and TX RDY from Q-bus data is done 
at CPT60-CPT90. THus, these bits will 
be stable at CPT200 when read on the ID 
bus. This is so microcode can be in a 
tight loop on RDY or DNE setting and the 
LSI-11 can set the bit from the Q-bus 
during reference on the ID bus to the 
same bit. 

3) TX RDY and RX DNE are not 
automatically set by a reference on the 
Q-bus to FM ID or TO ID; they must be 
explicitly set by the LSI-11. 

20: To ID register, low half - TO ID LO - R/W 
22: To ID register, high half - TO ID HI - R/W 

These two registers contain the 32 bits which microcode will read 
(into the Q-register in the CPU) when doing a read reference from 
ID bus address 05(16). See the TO ID register. The data in TO 
ID LO and TO ID HI is also the data placed on the ID bus during 
an ID bus write cycle invoked by the ID C/S register. They are 
readable for diagnostic purposes. 

24: From ID register, low half - FM ID LO - R/O 
26: From ID register, high half - FM ID HI - R/O 

These two registers permit reading data loaded into the FM ID 
register on the ID bus as a result of a write reference to ID 
address 07(16). In addition the FM ID LO and FM ID HI registers 
are loaded with the ID bus data during an ID bus read cycle 
invoked by the ID C/S register. 

30. ID Control/Status - IDC/S - R/W 

The IDC/S is used to monitor the ID address and direction lines, 
(see ID bus specification) and control console-generated ID bus 
cycles directly. Combined with the ID DATA registers, the TO ID 
registers, and the FM ID registers, it permits reading or writing 
any ID address while the clock is running or in single step mode, 
and reading any ID address when the clock is stopped. Note that 
writing ID registers still requires stepping the clock if it is 
not running. 

IDCS<15> - ID CYCLE - R/W 
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When written as a 1, ID CYCLE will cause ID MAINT to be asserted 
for one clock cycle (CPTO to CPTO) if the clock is running, or 
asserted at the next CPTO if single stepping. ID CYCLE is 
cleared automatically at the end of the ID cycle; therefore, the 
LSI-11 will normally read it as a zero, unless stepping in single 
time state mode. See ID MAINT description. 

IDCS<14> - ID REC WRITE - R/0 
IDCS<13:8> - ID REC ADDRS<5:0> - R/0 

These 7 bits allow reading the state of the ID bus left address 
and direction lines, and are valid only when the clock is 
stopped. NOTE: Due to receiver inversions, these bits will be 
read as the complement of the logical state of the corresponding 
bus wire. On these lines, logical 1=+3V, which will be read as a 
0. 

IDCS<7> - ID MAINT - R/W 

ID MAINT will assert automatically at the next available CPTO 
following writing a 1 to ID CYCLE, and remain asserted until the 
following CPTO, when it is cleared. This bit steers the MUX in 
the CPU which selects the source of the ID bus address and WRITE 
lines from the CPU or the console. During the time ID MAINT is 
asserted, the ID bus address and WRITE lines will be sourced from 
IDCS<6:0>. 

If the CPU clock is running, ID MAINT is read only, and writing 
to it has no effect. Note that if the clock is running, it would 
be read as a by the LSI-11 since it is asserted only for a 200 
nanosecond cycle. 

If the CPU clock is not running (i.e., CLK STOPPED is set - see 
MCR description) , then the LSI-11 may set and clear ID MAINT by 
writing a one or zero to it. Note that this permits statically 
reading ID registers via the ID DATA registers. 

The address and WRITE fields may be loaded in the same 
instruction that writes a "one" to ID CYCLE or ID MAINT. 

Both ID CYCLE and ID MAINT are cleared by LSI-11 system 
initialize. 

IDCS<6> - ID WRITE - R/W 
IDCS<5:0> - ID ADDRS - R/W 

These bits are loaded with the address and direction to be used 
during an ID cycle invoked by ID CYCLE, or while ID MAINT is 
asserted. IDC/S<6>, the WRITE bit, should be set to invoke a 
write cycle, and cleared to invoke a read. The ID ADDRS bits are 
loaded in true form (unlike the REC ADDRS bits, which are read 
inverted). In addition, these bits are cleared by LSI-11 
initialize. 
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32: 



For writes, data is sourced from the TO ID registers. For reads 
(static) the data is read in the ID DATA registers, while for 
dynamic reads the data is available in the FM ID registers 
following the cycle. 

See details on use of the IDC/S. 

Machine Control Register - MCR - R/W 



NOTE 

R/Wl indicates a bit that is readable; 
to clear it, a "one" is written to that 
position. 



MCR15 - Halt Request - HLT REQ - R/W 

Set by the LSI-11 to force microcode to the console wait loop. 
The VAX 11/780 CPU will recognize this request and set a HALT 
PENDING flop. Upon passing through the IRD state, if the HALT 
PENDING is set, microcode will set a Console Command Mode 
(CNSL CMND MODE) bit and enter the console wait loop, 
indicated by the assertion of HALT STATE (see MCS bit 7). A 
microcode CONTINUE function, invoked by the console, will 
reset both the HALT PENDING flag and CNSL CMND MODE, and enter 
IRD. If HALT REQ is still set, HALT PENDING will again set, 
but not until leaving IRD. Hence, a CONTINUE with HALT REQ 
set results in a single instruction execution. To resume 
normal instruction execution, the LSI-11 must first clear HLT 
REQ, then issue a CONTINUE function. Cleared by system 
initialize. 



NOTE 

Microcode can branch on the state of the 
CNSL CMND MODE bit. This is so that 
microcode can tell, in various error 
routines, whether the routine was 
entered as a result of some 
console-requested function or normal 
machine execution. 



MCR14 - Reserved 
MCR13 - Reserved 
MCR12 - CPU reset - CPU RESET - R/W 

When set, CPU RESET will force assertion of the (DC LO 
equivalent) internal initialization signal. Upon 
de-assertion, microcode will enter the power-up initialization 
microcode. Cleared by LSI-11 system initialize. 
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MCR11 - Reserved 

MCR10 - Maintenance return enable - MAINT RET ENABLE - R/W 

Writing a "one" to this bit causes a maintenance return. 
Specifically, the top element of the microstack is popped and 
J-field inputs are disabled. The result is a forced jump to 
the address on the top of the microstack. The actual signal 
to the microsequencer is asserted from approximately CPT150 to 
CPT50. If in single time state mode, MAINT RTN ENABLE will 
remain asserted from the time it was written as a "one" until 
the next CPT150 state is entered, when it will clear. 



NOTE 

The console should not attempt a MAINT 
RET function unless the CPU is in the 
console wait loop. 



MCR9 - Trap to writable control store - TRAP TO WCS - R/W 

When set, TRAP TO WCS will force bit 12 of the UPC to a "one" 
whenever a microtrap occurs, to force the trap into WCS. 
Should be set or cleared only when in the halt state or clock 
is stopped. Cleared by LSI-11 initialize. 

MCR8 - VAX 11/780 Interrupt Disable - VAX 11/780 INTR DISAB - R/W 

This bit, when set, disables the TX RDY and RX DNE interrupts 
to the VAX 11/780 CPU, regardless of the state of the TXIE and 
RXIE bits. Furthermore, it inhibits any change of state of 
the interrupt pending flops (on the CIB) in the terminal 
interrupt control logic. This bit is necessary to allow use 
of the ID registers and RDY and DNE bits for console functions 
without causing extraneous interrupts to the VAX 11/780 CPU. 



MCR7 - Rom no-op - ROM NOP - R/W 



This bit, when set, generates CLR UWORD and ABORT CYCLE in the 
microsequencer. This has the same effect as a STALL, to force 
•s on the various subsystem control fields so that random 



NOP 



patterns from WCS will not produce undesired side effects 
during testing. If set while the clock is stopped, it is 
necessary to step to a CPT0 before the effect of ROM NOP will 
be felt. Cleared by LSI-11 initialize. 

MCR<6> - Stop on microbreak match - SOMM - R/W 

When a match is detected between the microbreak register and 
the UPC, if S0MM=1, the clock is stopped in CPT0 of the cycle 
in which the match is occurring, and CLK STPD will be 
asserted. Cleared by LSI-11 initialize. 



VAX 11/780 CONSOLE SUBSYSTEM 



Page 8-17 



MCR<5> - Clock Stopped - CLK STPD - R/O 



This signal originates in the clock control logic and 
when the clock is not running. The signal will be net 



is set 
legated for 
one clock step or one cycle when either single time state or 
single cycle is stepped, but the LSI-11 is not fast enough to 
see this. However, the signal is also used in several places 
on the CIB to determine whether synchronizing to the clock is 
necessary or not. Cleared by LSI-11 system initialize. 



MCR<4:3> - Frequency select<l:0> - FRl and FRO - R/W 



These two 
follows: 



bits determine the clock frequency source as 



FRl 


1 

1 



FRO 


1 


1 



10.0 Mhz, (normal) 
10.525 Mhz, 5% short 
8.925 Mhz, 12% long 
external source 



FRl and FRO should not be changed if the 
Both are cleared by LSI-11 initialize. 



clock is running. 



MCR<2> - Single Time State - STS - R/W 

When the clock is running, setting STS will cause the clock to 
stop, in any of the four time states. As long as STS is set, 
and regardless of the state of SBC, writing a "one" to PROCEED 
will step the clock one time state (e.g., from CPT100 to 
CPT150). Cleared by LSI-11 initialize. 

MCR<1> - Single Bus Cycle - SBC - R/N 

If asserted (and STS=0) while the clock is running, the clock 
will stop in CPTO. As long as SBC is set (and STS=0) , writing 
a "one" to PROCEED will step the clock to the next CPTO (i.e., 
one ROM/SBI cycle). Cleared by LSI-11 initialize. 

MCRO - Proceed - PROCEED - W/0 



Writing a 
state (if 
STS=0 and 
Writing 
effect. Read 



"one" to PROCEED will either step the clock one time 
STS=1) or one cycle (if SBC=1 and STS=0) or, if both 
SBC=0, will start the clock running continuously. 



a "one" to PROCEED when the clock is running has no 
as a zero, cleared by LSI-11 initialize. 
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NOTE 

1) The proper method to stop the clock 
is via the SBC bit, so that the stopped 
state is known (CPTO) . 

2) CPT0=SBIT1, i.e., SBI time states 
lead the CPU by one time state. 

3) Clearing STS and SBC will not start 
the clock. it is necessary to write a 
"1" to PROCEED, after STS and SBC are 
cleared. 



34: The Miscellaneous Control and Status register (MCS) 

MCS<15> - Reserved 

MCS<14> - Reserved 

MCS<13> - Reserved 

MCS<12> - Floppy on - FLPY ON - R/W 

When set, applies power to the floppy disk drive via a relay. 
When cleared, removes power from the floppy. Set by LSI-11 
initialize. 

MCS<11> - Boot - BOOT - R/Wl 

Set by a — >1 transition of the boot signal from the control 
panel BOOT button. Cleared by writing a "one" or LSI-11 
system initialize. 

MCL<10> - Reserved 

MCS<9> - Console Command Mode - CNSL CMND MODE - R/O 

Permits reading the state of the CNSL CMND MODE bit. This bit 
is set by the microcode assertion of HALT STATE, and remains 
set until cleared by microcode while executing a CONTINUE 
function. 

MCS<8> - run - RUN - R/O 

This bit is the "1" side of a retriggerable one-shot clocked 
by the VAX 11/780 interrupt strobe signal, and will remain a 
"1" as long as the CPU is strobing interrupts at least every 
(TBS) microseconds. While the CPU is running and executing 
programs, negation of RUN generally indicates some type of 
problem; e.g., hung in a microcode loop or a hardware 
failure. This one-shot is also used to light the "RUN" 
indicator on the front panel. 
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MCS<7> - Halt State - HALT STATE - R/O 

This is the raw decoded output of a ROM field, which is 
asserted if and only if the microcode is in the console wait 
loop. This is required because CNSL CMND MODE, which is sot 
upon entry into the console wait loop, will remain set even if 
microcode leaves the loop. HALT STATE therefore is used to 
ascertain that microcode did return to the wait loop following 
a console microcode function (other than CONTINUE), and that 
microcode is in the wait loop prior to doing a console ID 
cycle. 

MCS<6> - Transmit Ready Interrupt Enable - RDY IE - R/W 

MCS<5> - Receiver Done Interrupt Enable - DNE IE - R/W 

These two bits enable the corresponding interrupt to the 
LSI-11 upon a 1-0 transition of the TX RDY or RX DNE bits. If 
TX RDY or RX DNE is already 0, and the corresponding IE is 
set, the interrupt will occur. Cleared by LSI-11 initialize. 

MCS<4> - Reserved 

MCS<3> - Reserved 

MCS<2:0> - Panel switch sense - R/O 

These 3 bits sense the position of the control panel switches 
as follows: 

MCS<2> - Auto restart switch - AUTO RST - R/O 
MCS<1> - Remote mode - REMOTE - R/O 
MCS<0> - Lock - LOCK - R/O 



The V-bus register 

In addition to the V-bus functions, V-bus <7:4> permit reading the 
state of the CP clock as follows: 

V-bus<7> - CPTO 
V-bus<6> - CPT1 
V-bus<5> - CPT2 
V-bus<4> - CPT3 

These bits are read-only and meaningful only when the clock is 
stopped . 
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LSI-11 interrupts 

Vector Priority What 

300(8) higher TX RDY 

304 (8) lower RX DNE 

8.4 USE OF THE Q-BUS REGISTERS 
Program I/O 



Program I/O mode is when the FM ID and TO ID registers are used as the 
TXDB and RXDB respectively when VAX 11/780 software wishes to 
communicate with the LSI-11 or the operator terminal, via MTPR's and 
MFPR's. Figure 8-5 shows the interaction between VAX 11/780 
macrocode, microcode, and LSI-11 software. (ISR:=interrupt service 
routine) . 

Console microcode routines 



When the CPU is in the console wait loop, the console may request 
microcode routines to perform various functions, such as an examine 
virtual address. The TO ID and FM ID registers are used to pass 
parameters needed or supplied by these routines, and the transfers are 
interlocked in a manner similar to Figure 8-5, except that instead of 
the setting of TX RDY or RX DNE interrupting the VAX 11/780 CPU, it is 
VAX 11/780 microcode's responsibility to test the appropriate bit for 
being a "one" before reading or loading the TO ID or FM ID register 
over the ID bus. 

The LSI-11 forces entry to those microroutines by writing to the 
microstack via the ID bus (see next section), which pushes the address 
on the microstack, then asserting MAINT RTN in the MCR. All console 
microroutines except CONTINUE must exit back to the console wait loop. 



VAX 11/780 MACROCODE 



MICROCODE 



LSI-11 SOFTWARE 



***************** 

* * 

* TX RDY ISR * 

* * 
***************** 

I 

/ \NO 

/ TX RDY = 1? \— 
/ \ 



I YES 
***************** 

* MTPR, * 

* DATA, *- 

* TXDB * 
***************** 

I 
***************** 

* * 

* RE1 * 

* * 
***************** 



************ 

->*ERROR * 
************ 



*********************** ***************** 

* * TX RDY < — * * 
->* FM ID< DREG *- >* TX RDY ISR * 

* * INTR LSI-11 * * 

***************** 

I 



*********************** 
(VIA ID BUS) 



INTR VAX 11/780 CPU 
- - - - -<- - - - - - 



***************** 

* * 

* TX RDY ISR * 

* * 
***************** 



/ \NO 

/ TX RDY = 0? \— 

/ \ 



I YES 
***************** 

* READ FM ID * 
-* TX RDY< — 1 * 

* * 
***************** 



************ 

*RTI * 

************ 



************ 

->*ERROR * 

************ 
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There is of course the possibility that the PM ID and/or the TO ID 
register was in use for terminal I/O at the time of the entry to the 
console wait loop, either as a result of a halt instruction or an 
LSI-11 halt request such as for single instruction step. In order not 
to loose terminal data, the LSI-11 must do the following: (Figure 8-6 
will help follow this). 

1. If, at the time of the halt, the TX RDY bit=0, the LSI-11 
must first read the FM ID register (and presumably either act 
on the data or at least save it) and set the TX RDY bit. 
Note that this will set the TX RDY interrupt pending bit (if 
TXIE=1). If TX RDY=1, indicating no new data, go directly to 
2. 

2. If, at the time of the halt, the RX DNE bit=l, indicating the 
TO ID register has not yet been read by microcode, the LSI-11 
must save the content of TO ID and the state of the RX DNE 
bit. If RX DNE=0, indicating the buffer has been read, 
proceed to 3. 

3. Set VAX 11/780 INTR DISABLE. This now "freezes" the state of 
the VAX 11/780 interrupt control logic, and the TO ID and FM 
ID, and synchronizing bits, may then be used freely for other 
functions. 

When ready to continue, the LSI-11 must do the following: 

1. Set TX RDY. 

2. If RX DNE=0 upon entry (halt) , then clear the VAX 11/780 INTR 
DISABLE and go to 3. If RX DNE=1 upon entry, then restore 
data to TO ID and set RX DNE, then go to 3, else restore old 
data to TO ID, set RX DNE, and issue the continue. 

3. Re-enable VAX 11/780 interrupts; enable LSI-11 interrupts; 
issue CONTINUE. 
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This sequence is necessary for two reasons: to prevent causing 
spurious interrupts to the VAX 11/780 CPU, and to ensure the 
interrupts do occur during single instruction stepping. 

Direct ID bus references 



1. Clock running 

Writing to ID registers is accomplished by first loading the 
data to be written into the TO ID LO and TO ID HI registers, 
then writing the register address, with the WRITE bit=l and 
ID CYCLE=1, into ID C/S. ID CYCLE may be set by a separate 
instruction, but in either case the data from the TO ID 
register will be written into the addressed register. 

Reading is accomplished similarly, except that the ID WRITE 
bit=0 (i.e, read), and the data from the specified register 
is available in the FM ID LO and FM ID HI following the 
cycle. 

2. Clock stopped 

Reading ID registers with the clock stopped (presumably in 
CPTO) is done by setting ID MAINT in the ID C/S register, and 
placing the desired address in the address field, with 
WRITE=0. Since all ID register strobes are disabled in CPTO, 
it is necessary to step the clock to whichever state, other 
than CPTO, the desired register is gated onto the ID bus. As 
long as ID MAINT is set, the clock is in the correct time 
state, and WRITE=0, the addressed register may be read 
through the ID DATA LO and ID DATA HI registers, and the 
address may be changed while ID MAINT is set. ID MAINT 
should be cleared prior to starting the clock again. 

It is impossible to write to ID registers when the clock is 
stopped without stepping through time states. However, ID 
writes may be accomplished by first ensuring the clock is in 
CPTO, then loading the desired ID address into ID C/S, along 
with ID MAINT=1, and the data in TO ID LO and TO ID HI. 
Invoking a single cycle via PROCEED will then write the TO ID 
data to the selected register, and clear ID MAINT. Reads may 
be done in a similar manner. 
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8.5 TERMINAL CONTROL REGISTERS IN THE PROCREG SPACE 

The following is a proposal for the terminal communication registers 
which must appear in the processor register space. The interface 
basically consists of a transmitter and a receiver data buffer 
register 16 bits in width, and appropriate control and status 
information for each. 

Note that bits <11:8> of the data buffers are used as a "unit code", 
with unit code 00(8) assigned to the operator terminal. This is so 
that the interface may be "subsetted" to a simple terminal interface 
on those implementations which have only that basic functionality. 
There may be a bit which indicates that the interface can do more than 
simple terminal functions; if so, that bit belongs in a CPU 
configuration register (TBS in Chapter 9), not in the control/status 
registers defined below. 

Please note that this appendix describes the terminal registers as 
seen by macro level software via MTPR's and MFPR's, independent of 
specific implementations. Section 3.0, on the other hand, describes a 
set of registers on the ID bus as seen by microcode, and which will be 
used in the VAX 11/780 implementation to materialize these terminal 
registers (among other things). 

This proposal, in some form, will be ECO'd into Chapter 9 to provide 
the TBS's for the terminal registers. 
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RXC/S - Receiver control/status 

RXCS<7> - receiver done - read only 

Set when the data in RXOB is valid and ready to be 
read. Cleared by reading RXDB or by system initialize. 

RXC/S<6> - receiver interrupt enable - read/write 

When set, enables an interrupt to the CPU whenever 
receiver done becomes set. Cleared by program control 
or by a CPU reset. 

RXDB - Receiver data buffer - read only 

RXDB<7:0> - receive data 

Contains one byte of data from the unit specified in 
RXDB<11:8>. 

RXDB<11:8> - receive unit select 

RXDB<11:8> specify from which logical unit the data in 
RXDB<7:0> originated. Logical unit 00 is reserved for 
the operator terminal. 

Reading RXDB automatically clears receiver done in the RXC/S longword. 
Reading RXDB when receiver done is zero has UNPREDICTABLE results. 

TXC/S - Transmitter control/status register 



TXC/S<7> - transmitter ready - read only 

When set, indicates that TXDB is ready to accept 
another character for transmission. Cleared by a write 
to TXDB; set by a CPU reset. 

TXC/S<6> - transmitter interrupt enable - read/write 

When set, enables an interrupt which occurs whenever 
transmitter ready becomes set. Cleared by program 
control or by a CPU reset. 

TXDB - transmit data buffer - write only 

TXDB<7:0> - transmit data 

Written by program with the character to be transmitted 
to the logical unit specified by TXDB<11:8>. 

TXDB<11:8> - transmit unit select 

Written along with TXDB<7:0> to specify the logical 
destination of TXDB<7:0>. Logical unit 00 is reserved 
for output to the operator terminal. 

Writing to TXDB clears transmitter ready in TXC/S. Writing to TXDB 
when transmitter ready is zero has UNPREDICTABLE results. 
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Note that when this interface is used for the operator terminal, the 
logical unit select fields are both all zeros and the interface 
appears much like a minimal DL-11. In the VAX 11/780 implementation, 
non-zero unit select fields may be used to initiate I/O with other 
devices (namely, the floppy) , or general software communications with 
the LSI-11. Should software attempt communications to/from units 
other than unit zero on those implementations which have only the 
terminal, bits <15:8> are ignored and the characters still go to the 
terminal, which possibly prints garbage. This is probably acceptable, 
since it is the result of a clear-cut software error. 



CHAPTER 9 
VAX 11/780 ACCELERATOR INTERFACE 

The VAX 11/780 Accelerator interface provides mechanisms for: 

1. Main Machine/Accelerator synchronization, 

2. Explicit control of the Accelerator machine state by the main 
machine. 

3. Transferring of main machine control to Internal WCS space by 
the Accelerator at any arbitrary Decision Point. 

4. Instruction stream interpretation by the Accelerator. 

5. Transfer of 32 bit data words from the ISB to the 
Accelerator, from the Accelerator to the main machine Data 
Path or from the main machine Data Path to the Accelerator. 
Also, provision is made for incorporating within the 
accelerator single or multiple copies of the processor 
general register set. 

6. Transfer of Accelerator status flags into the main machine 
micro control machine branch logic. 

7. Transfer of condition code information into the main machine 
condition code logic. 

Each of these mechanisms is defined in such a way that the use may be 
defined to suit a general Accelerator. 

Each of these functions will be described in more detail in succeeding 
sections of this specification. 
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in summary, the Accelerator interface allows the Accelerator to 
examine the instruction stream and "pick out" instruction operation 
codes which it determines belong to it and then transfer control of 
the main machine to an "Accelerator handler" in main machine WCS while 
it processes the instruction. 



9.1 DEFINITIONS 

INSTRUCTION STREAM BUFFER (ISB) - The Instruction pre processing 
hardware which pre fetches and decodes operation codes and operand 
specifiers from the process Instruction Space. 

CENTRAL PROCESSING UNIT (CPU) - The processing hardware consisting of 
control store, control machine, registers and data processing hardware 
which comprises the basic VAX 11/780 computer. 

ACCELERATOR - An optional, autonomous, data processing machine which 
operates in conjunction with the CPU to increase processing speed for 
specific instructions within the VAX-11 architecture. This is 
accomplished by transparently (at the macro level) overriding 
emulation of those instructions by the CPU and instead causing the 
required processing to be accomplished in the Accelerator, whose 
processing elements are optimized to perform the required operations. 



9.2 INTERFACE SPECIFICATION 

Figure 9-1 depicts a block diagram of a VAX 11/780 ACCELERATOR 
interfaced to the VAX 11/780 Computer System. This diagram will be 
referred to throughout the remainder of this specification. 



9.3 GLOSSARY OF INTERFACE SIGNALS 



1. OP CODE: Eight bits of information from the ISB which are a 
copy of the data contained in byte (OP CODE byte) of the 

ISB. 

2. EXECUTION POINT COUNTER - Three bits from the ISB which 
denote where in the process of instruction execution of the 
CPU is. The case of execution point counter * and an 
enable signal from the ISB is used to determine that the CPU 
is presently in the IR DECODE state. 

The Accelerator also uses the Execution Point Counter to 
determine when to force CPU control to WCS. 
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3. SRC1 SPECIFIER TYPE: Three signals from the ISB which 
determine the location of data referenced by the Operand 
Specifier in byte 1 of the ISB. The encoded locations are: 

CODE 

Oil Data is in General Register 
111 Data is in Memory 
110 Data is Short Literal 
101 Data is Immediate 

All other codes cannot occur. 

4. SRC2 SPECIFIER = REGISTER: One bit which when asserted 
indicates that the byte of Data in byte 2 of the ISB would 
evaluate to Register if it is an operand specifier. The only 
time this is meaningful is if SRC1 specifier is one byte in 
length. 

5. VALID: Four signals from the ISB which indicate to the 
accelerator whether or not the information on the OP CODE, 
SRC1 SPECIFIER TYPE and SRC2 SPEC = REGISTER lines is valid. 
The signals are as follows: 

BYTE VALID (OPCODE VALID) 
BYTE 1 VALID (SPECIFIER 1 VALID) 
BYTE 2 VALID (SPECIFIER 2 VALID) 
STALL + SVC (ALL INFORMATION VALID) 

6. REGISTER NUMBERS: Two four bit quantities which designate 
the registers denoted by SRC1 and SRC2 operand specifiers if 
they are indeed Register Operand Specifiers. These may be 
used by the accelerator to pre-fetch register contents at the 
beginning of each IRD to expedite operations involving 
register data. 

Note that these register numbers will be undefined for 
operand specifiers other than SRC1 = SRC2 = Register. 

7. DECISION POINT OVERRIDE: A signal from the ACCELERATOR to 
the CPU control machine which, when asserted, will 
unconditionally assert Address Bit 12 on input of the micro 
sequencer address mux. The effect of this is to cause 
transfer of control to the internal WCS module at the current 
execution. 
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8. ID BUS: The 32 bit bidirectional bus which is the main 
mechanism whereby data is entered into the Accelerator. 

9. ACCELERATOR CONTROL FIELD: This is a two bit field used to 
command the operation of the Accelerator. Three of these 
codes are fixed use and the fourth is accelerator dependent. 
The codes are: 

ACF 00 - NO OPERATION 
01 - CPU SYNC 

10 - ACCELERATOR TRAP 

11 - ACCELERATOR SPECIFIC CODE 

The CPU trap and CPU sync codes will be used by the power up 
or abort micro routines. Therefore, all accelerators must 
use these codes. 

CPU SYNC: One signal, derived from the ACF field, which is 

used to synchronize CPU and Accelerator functions. It 

functions as a binary semaphore or flag which is tested by 
the Accelerator when synchronism is required. 

ACCELERATOR TRAP: A signal from the ACF Field which when 
asserted will cause a transfer of control within the 
Accelerator to the micro address specified by the TRAP 
ADDRESS word in the next micro cycle. 



10. TRAP ADDRESS: 3 bits from the CPU control word which specify 
explictly the micro address in the ACCELERATOR Control space 
to which ACCELERATOR Control is to be transferred. These 3 
bits are formed by redefining the (USI) field in the CPU 
control word. 

11. ACCELERATOR STATUS FLAGS: Three bits which are passed from 
the ACCELERATOR to the CPU control machine branch logic. 
These bits can be tested by the CPU by selecting BEN 6. The 
meaning of these bits varies with the state of the 
CPU/Accelerator machine combination. 

Once convention is established, however, in cases where 
synchronization is required. ACC<00> is defined AD HOC to be 
the signal Accelerator Sync. This signal is tested by the 
CPU at synchronizing points and together with CPU sync forms 
a bidirectional synchronization interlock. NOTE: That 
ACC<02:01> remain free of definition even during 
synchronization. Therefore, information may be passed to the 
CPU and interpreted in context at each synchronization point 
by the ACCELERATOR if so desired. 
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12. ACCELERATOR CONDITION CODES: The Accelerator has access to 
the PSL condition codes from the CPU. For each instruction 
implemented by the Accelerator, the PSL condition codes may 
want to be changed. Therefore, the Accelerator takes the PSL 
condition codes at the start of the instruction and returns 
four new condition code bits based on the result of the 
operation and the previous condition code states 
NOTE: That these return lines are different than the 
condition codes coming to the accelerator. The returned 
condition codes are latched by the CPU. This information is 
then transfered to the PSL condition codes in the next CPU 
micro state by setting the UMSC field to a 6. 

13. GENERAL REGISTER ADDRESS: Four signals from the CPU control 
machine which are latched copies of the SPA address (latched 
in the CPU at T150) . During the second half of each micro 
cycle (T100— >T0) the address lines of the internal 
ACCELERATOR General Register sets are forced to agree with 
this address. It is during this time that any updates to the 
CPU general register are copied into the ACCELERATOR General 
Registers Copies. 

14. GENERAL REGISTER WRITE ENABLE: Two bits which encode how 
much, if any, of the general register addressed by the 
General Register ADDRESS lines is being written in the CPU. 
The codes are as follows: 

WREN 01 00 

1 1 No Write 

1 Write Byte (Byte 0) 

Write Word (Bytes 0, 1) 

1 Write Long Word (Bytes 0, 1, 2, 3) 

These bits are latched in the CPU at T150 of each micro 
cycle. 

15. GENERAL REGISTER UPDATE BUS: 32 data lines from the CPU to 
the Accelerator. These lines are a buffered copy of the data 
inputs to the CPU general register sets. This is the data 
written into the ACCELERATOR General Register Copies when an 
update is indicated by WREN<00:01>. This bus is also used to 
return data back to the CPU. It is the task of the 
Accelerator to decide which data to return. Control of the 
direction of transfer on this bus is done by a control code 
in either UQK or the UDK fields in the CPU. 

16. ISB CALL: A signal from the ISB to the ACCELERATOR which 
when asserted indicates that I Stream Data (either short 
literal or Immediate Data) is being driven onto the ID Bus by 
the ISB during the current cycle. 
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9.4 ACCELERATOR INTERFACE OPERATION 

CPU < — ACCELERATOR INTERFACE 

The main function of the CPU/ACCELERATOR Interface is to P ro *"l 
synchronization between the two cooperating processes and to pass 
status information for the purpose of altering control flow in either 
or both machines. 

Synchronization is obtained by the use of semaphores. WJjJJ 
Synchronization is required, the following sequence^ o v t 
transpires (refer to figure 9-1). For the purpose of ^"Sj"* 1 ™ 
synchronization of a data transfer from the CPU to the ACCELERATOR is 
discussed. NOTE: That this transfer of condition codes must be done 
at a syncronization point defined by accelerator and CPU micro code. 



9.4.1 Data transfer 

The example of Figure 9-2 shows a transaction in which a data word is 
being fetcned from memory by the CPU. In this example, the 
aScSlERAtSr is waiting for the Data and indicates such by assert 
ACCEL SYNC. In each micro cycle while it is waiting for CPU SYNC the 
ACCELERATOR reads data from the ID bus and treats it as if it were tne 
datf it was expecting. In some cases, the ACCELERATOR may even begin 
Processing this data if it can safely do this without destroying any 
internal information required at a later time. 

Meanwhile, the CPU generates the Virtual Address of the required data 
and completes the memory reference. 

Note that any faults encountered in this memory r eference have no 
effect on the ACCELERATOR state - hence servicing of TB faults, cache 
parity errors, unaligned data traps, etc., can occur transparently. 

Once the memory reference has been successfully completed and the data 
safely stored in the CPU D register, the CPU drives it onto the ID bus 
and asserts CPU SYNC. In this state, it tests for ACCEL SYNC and 
finding it asserted, continues. 

The ACCELERATOR, meanwhile, has finally received CPU SYNC pleating 
that the data which it has received was indeed the data it required 
and it continues processing. 

9.4.1.1 Initia l data transfer - The bi-directional interlock shown in 
Fiqure 9^2 — is not always necessary. In some cases, (noteably during 
initial argument loading or whenever the ACCELERATOR is guaranteed to 
be idle (i.e., waiting for data input) the test for ACCEL SYNC by the 
CPU may be safely bypassed as in Figure 9-3. 
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Note also in Figure 9-3 that the ACCELERATOR is designed in such a way 
that it is, after receipt of the first argument, continuously using ID 

bus data for processing as if it were valid data and storing the 

result in a scratch register while waiting for CPU SYNC. When the CPU 

SYNC is received, indicating that the data is on the ID BUS in the 

current cycle, the ACCELERATOR has already successfully completed one 
micro cycle of its required execution. 



9.4.2 Accelerator control 

In addition to synchronization of the ACCELERATOR and the CPU, the 
interface provides two mechanisms whereby the CPU may explicitly alter 
control flow in the ACCELERATOR. 



9.4.2.1 Accelerator trap - The first is the ACCELERATOR TRAP 

function. When the CPU wishes to force the ACCELERATOR control 

program to a specific uaddress it asserts this uaddr on TRAP 

ADDRESS<03:00> and asserts ACCEL TRAP. (See Figure 9-4). 

In the following ustate, ACCEL control will be unconditionally 
transferred to this micro address. Figure 9-4 illustrates how the CPU 
would use the ACCEL TRAP function to cause a transfer of control 
within the ACCELERATOR control machine to uAddress 6. This mechanism 
would be used primarily for initialization of the ACCELERATOR and 
perhaps in some catastrophic fault conditions. 



9.4.2.2 Alternate trap function - Each implementation of Accelerator 
will likely require a means of subroutine calls. This can be 
implemented in a few different ways. One approach would be the 
complex scheme of a micro stack with call and return capabilities. 
Another means could be a trap to a specific address. This may be done 
by a field of bits located in the Accelerator maintenance register. 
This would allow routines to be entered where there is enough overhead 
available to allow a constant to be written into the status register. 
These traps could also be defined to imply syncronization points. 

The most useful need for this appears to be for micro diagnostics. 



9.4.2.3 CPU branches - As has previously been discussed, the primary 
mechanism for passing control/status information from the ACCELERATOR 
to the CPU is the three bit ACCEL STATUS FLAG Field. 

One of these three bits (i.e., bit 0) is predefined to be ACCEL SYNC. 
The remaining two however may be used to convey different information 
at different times. Within the CPU these three bits form one branch 
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enable input into the control machine. Thus, at any synchronization 
point, an eight way branch within the CPU can be used to test internal 
Accelerator conditions (ACC<00> is predefined as ACCEL SYNC. 

The ACCELERATOR control machine may, at different sync points within a 
given execution, switch these status flag inputs to various internal 
hardware outputs such as "overflow detected", "undefined variable", 
etc., or drive the bits directly. The only requirement is, of course, 
that the CPU recognize what significance these bits have in current 
context. 



9.4.3 System clock 

One important item which has not been mentioned yet but rather assumed 
is the SYSTEM CLOCK input to the ACCELERATOR. Both the CPU and 
ACCELERATOR use this system clock for timing. Furthermore, both 
control machines utilize synchronous 200 nsec u states (i.e., 
ACCELERATOR TO = CPU TO etc.) as far as the control interface is 
concerned. 

Clock inputs are differential ECL and consist of decoded TO, T50, 
T100, T150 as well as Tph and the two phase clocks. (See VAX 11/780 
Clock Spec.) Thus, with some care 25 nsec intervals within the 200 
usee ROM state can be established within the data prcoessing section 
of the ACCELERATOR. 



9.5 DATA INTERFACE 

Connecting the ACCELERATOR and the CPU are two 32 bit data busses, the 
System ID Bus and the ACCELERATOR GEN REG Bus. 



9.5.1 Data to accelerator 

Data is transfered to the Accelerator by means of the system ID BUS. 
This transfer is done by the CPU asserting data onto the ID BUS and 
issuing CP SYNC. This implies that the transfer is done at a sync 
point. Note that no ID bus address is required for this transfer. 
The Accelerator simply accepts the current ID bus data. 



9.5.1.1 Data from accelerator - Results returned from the accelerator 
is done via the Accelerator General Register Bus. This transfer is 
done by the CPU selecting the Accelerator data onto the 3-state 
general register bus. This implies that this transfer is done at a 
syncronization point where the data is meaningful. 
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9.5.2 Alternate data transfers 

The data returned from the Accelerator could also be accomplished over 
the system ID bus. There are two drawbacks to this scheme. First is 
the timing consideration of when the result data is stable it must be 
stable sooner for an ID bus transfer. The second drawback is that the 
ID bus data can only go into the CPU Q Register. This implies that if 
the data is to be written to memory, an additional state of overhead 
is added. 



9.5.3 Accelerator status registers 

In addition to serving as a path for input and output data, the System 
ID bus provides READ/WRITE Access to the ACCELERATOR STATUS and 
MAINTENANCE registers. The ACCELERATOR STATUS register is accessible 
to macro level software via MTPR and MFPR instructions. Both 
registers are accessible to the console processor. 

By examining this register (bits 0-3) the console (or macro level 
software) can determine what type (if any) ACCELERATOR is installed. 

By writing bit 15 of the ACCEL STATUS register the console or macro 
level software may at any time turn the ACCELERATOR on or off. 
Turning the unit off will disable all control output signals which 
effectively removes the ACCELERATOR from the system. This allows the 
system to continue operation in degraded mode for most ACCELERATOR 
failures. 

Bits 30 thru 27 contain error information based on the particular 
accelerator type. 

Bit 31 is an error summary flag which is set when any of the error 
bits (30:27) are set. 



9.5.3.1 Accelerator maintenance register - This register contains 
information useful to micro diagnostic programs. (Accelerator 
Dependent) 



9.5.4 General register updates 

A second method of passing data to the ACCELERATOR would be through 
the processor General Register set. Provision for maintaining "n" 
copies of the processor General Register set within the ACCELERATOR is 
provided. The ACCELERATOR may Read data from these internal copies 
from TO to T100 of any micro state. It then relinquishes control of 
these copies to the CPU via the General Register Address, Data and 
Write enable lines of the CPU/ACCELERATOR interface. 
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During this portion of the cycle the CPU will cause the ACCELERATOR 
General Register copies to be written (updated) in an identical manner 
to the CPU general register sets. 

Note that the ACCELERATOR General Register copies are WRITE ONLY 
Memory to the CPU and READ ONLY Memory to the ACCELERATOR. Operations 
with destinations within the general register set processed by the 
ACCELERATOR still require passing of the result through the CPU D 
register. The purpose of this section of the DATA INTERFACE is to 
provide rapid access to data contained in the General Register sets bv 
the ACCELERATOR. y 



9.6 I SB INTERFACE 

A key to the operation of the ACCELERATOR is enough visibility of the 
I stream and CPU machine state to be able to determine: 

1. When to begin processing an instruction (i.e., when the CPU 
is in IRD) . 

2. When to force the CPU control flow into the WCS Accelerator 
handler package. 

This is accomplished by, in the ACCELERATOR quiescent state (WAIT) 
examining the output of an "ON BOARD" instruction decode network. All 
u address targets for the ACCEL control machine are the WAIT state 
except for the instructions for which the unit was designed. 
Furthermore, this target uaddress is forced to the WAIT STATE address 
except when the CPU is in IRD, no interrupts or exceptional conditions 
are pending, and the ISB data being supplied is valid. 

When the ACCELERATOR has determined that it should begin execution, it 
leaves WAIT and the on board decode has no further function until the 
next IRD state. 

At some point in the CPU control program, the ACCELERATOR will 
determine that the general flows provided in the CPU micro code do not 
efficiently serve its requirements and it will assert EXECUTION POINT 
OVERRIDE. This will force a one to micro address bit 12. The net 
effect of this action is to force transfer of control in the CPU 
control machine to the WCS module at the next Decision Point. 

Note that the 8 bits being asserted by the Instruction Buffer are 
unmodified by this action. Therefore, each target uaddress which 
might occur in the normal flow must be duplicated in the WCS handler 
Worst Case this would be 256 locations, but this number should be 
considerably smaller. 
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FIGURE 9-1 
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CREATE VA 
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ACC SYNC 
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I STILL WAITING 

I ACC<-ID BUS 
| WAIT FOR 
I CP SYNC 



I 



SEND DATA 



I ID<-D 

I CP SYNC<-1 



l<- 



ACC SYNC 



>| 



ACKNOWLEDGE 



ACC<-ID BUS 



ACC SYNC 



DONE XFER 



I 


-ACC 


SYNC 


1 1 


I ID< 
I CP 


:-d 

SYNC 


1 
1 



FIGURE 9-2 



VAX 11/780 ACCELERATOR INTERFACE 



Page 9-13 



CPU 



ACCEL 



I CREATE VA FOR I 
1 FIRST MEM REF | 


CPU SYNC | 


WAIT FOR 1ST DATA | 
WORD | 




STORE ID BUS DATA | 
BRANCH ON CPU SYNC | 


1 


CPU SYNC 


1 DO FIRST MEM | 
I REF-GET ADDITIONAL I 
1 OP SPEC INFO | 


WAIT FOR 10 DATA | 
WORD | 


I DREG<-CACHE I 
I QREG<-ID BUS | 


STORE ID BUS DATA | 
BRANCH ON CPU SYNC | 


1 


CPU SYNC 


I FORM NEXT VA | 
|& PASS DATA TO ACCEL | 


WAIT FOR 1ST | 
DATA WORD | 


1 ID BUS<-DREG | 
1 rrn QVNf^ l I — 


STORE ID BUS DATA | 
BRANCH ON CPU SYNC | 




CPU SYNC | 


1 


CPU SYNC 


I DO SECOND MEM | 
I REF | 


WAIT FOR 2ND I 
DATA WORD | 


1 DREG < -CACHE I 


OPERATE USING I 

ID BUS DATA | 

TEMP< — RESULT I 

BRANCH ON CPU SYNC | 


1 


CPU SYNC 


I PASS 2ND DATA I 
I WORD TO ACCEL I 


WAIT FOR 2ND | 
DATA WORD | 


I ID BUS<-DREG I 
1 pdii cvur^ i 1 


OPERATE USING I 

ID BUS DATA | 

TEMP<-RESULT | 

BRANCH ON CPU SYNC I 


1 v»rU DIIMv^V. — J. | 


Figure 9-3 
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APPENDIX A 
CONTROL WORD 



THE SIX (6) IK * 4 ROMS USED FOR VAX MODE ON THE IRC MODULE ( M8224 ) 
MAKE UP A 12 BIT CONTROL WORD WHICH IS USED TO DETERMINE THE MAJOR 
EXECUTION POINTS OF THE INSTRUCTIONS. THE 12 BIT FIELD IS SPLIT INTO 
THREE (3), FOUR (4) BIT FIELDS WHICH ARE: 



BITS 

3:0 
7:4 
11:8 



FIELD 

ADR 
CTL 
CTX 



DESCRIPTION 

ADDRESS 
CONTROL 
CONTEXT 



A.l THE CONTROL WORD 

THE CONTROL WORD IS SHOWN BELOW. 

| VAX DECODE 

| CONTEXT I CONTROL 



ADDRESS 



I I I I I I I I I I I I 
I LENGTH | TYPE I ACCESS I MODE I 16 WAY ADDRESS 

I I I I I I I I I I I I 



CTX3 CTX2 CTX1 CTXO 07 



06 



05 



04 



03 



02 01 



00 



ADDRESS: THE ADDRESS FIELD IS USED TO PROVIDE A 16 WAY LITERAL 
DISPLACEMENT WHEN GENERATING AN EXECUTION ADDRESS. THE 
ADDRESS IS ONES COMPLEMENTED BEFORE GOING TO THE MICRO 
SEQUENCER. 

EXAMPLE: IF BITS 03:00 = 5, THEN THE ADDRESS FIELD ON 
THE INPUT TO THE MICRO SEQUENCER WOULD BE AN 
"A". IN THIS CASE ALL EIGHT (8) VAX DECODE BITS 
ARE ONES COMPLEMENTED. 
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CONTROL: THE CONTROL FIELD IS SPLIT INTO TWO (2) ,TWO (2) BIT 
FIELDS WHICH ARE THE "MODE" FIELD ( BITS 05:04 ) AND 
THE "ACCESS" FIELD (BITS 07:06). THESE FIELDS ARE DE- 
CODED AS FOLLOWS: 



MODE: 05 I 04 





1 

1 





1 


1 



OPERATION 



SELECT SPECIFIER 

EXECUTE IF R MODE ( ONE OPERAND ) 
OPTIMIZED ( TWO OPERANDS ) 
SELECT EXECUTE 



ACCESS: 07 






1 
1 



06 




1 


1 



OPERATION 



BRANCH 
READ 
WRITE 
MODIFY 



CONTEXT: THE CONTEXT FIELD IS SPLIT INTO TWO (2) ,TWO (2) BIT 

FIELDS WHICH ARE THE "TYPE" FIELD ( BITS CTX1:CTX0 ) 
AND THE "LENGTH" FIELD ( BITS CTX3:CTX2 ) .THESE FIELDS 
ARE DECODED AS FOLLOWS: 



TYPE: 



CTX1 





1 

1 



CTXO 




1 


1 



OPERATION 



INTEGER 
FLOAT 
VSRC 
ASRC 



LENGTH: CTX3 






1 
1 



CTX2 





1 


1 



OPERATION 



BYTE 
WORD 
LONG 
QUAD 



DEFINITIONS: 



SELECT SPECIFIER! 



THIS CODE IS USED TO SELECT THE SPECIFIER 
DECODE LOGIC. THE EXECUTION ADDRESS WILL BE 
DETERMINED BY THE ADDRESSING MODE OF THE SPEC- 
IFIER. THE ADDRESSES THAT CAN BE GENERATED BY 
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EXECUTE IF R MODE: 



OPTIMIZED: 



SELECT EXECUTE: 



BRANCH: 



THIS LOGIC ARE SHOWN IN THE SPECIFIER DECODE 
TABLE. 

THIS CODE IS USED TO CHECK IF THE SPECIFIER IN 
BYTE ONE IS REGISTER MODE. IF IT IS REGISTER 
MODE, THEN THE ONES COMPLEMENT OF THE VAX DECODE 
BITS 07:00 ARE USED AS THE EXECUTION ADDRESS. IF 
THIS CONDITION IS NOT MEET THEN THE SPECIFIER 
DECODE LOGIC IS SELECTED BY HARDWARE. 

THIS CODE CHECKS FOR SHORT LITERAL TO REGISTER 
( S~#,REG ). OR REGISTER TO REGISTER ( REG, REG ). 
IF EITHER OF THESE CONDITIONS ARE MEET, THEN THE 
HARDWARE WILL MODIFY THE SPECIFIER ADDRESS. IF 
THESE CONDITIONS ARE NOT MEET, THEN THE SPECIFIER 
ADDRESS IS NOT MODIFIED. 

WHEN THIS CODE IS USED, THE VAX DECODE BITS 07:00 
ARE ONES COMPLEMENTED AND USED AS AN EXECUTION 
ADDRESS. 

THE BRANCH CODE WILL SELECT THE BRANCH DECODE 
LOGIC ONLY AT EXECUTION POINT 0. AT ANY OTHER 
EXECUTION POINT THIS CODE CAN ONLY BE USED AS 
A LITERAL FOR AN EXECUTION ADDRESS. 



READ: 



WRITE: 



MODIFY: 



INTEGER: 



FLOAT: 



VSRC: 



THIS CODE IS USED WHEN A SPECIFIER EVALUATION 
WANTS TO READ DATA. THIS CODE CAN ALSO BE USED 
AS A LITERAL FOR AN EXECUTION ADDRESS WHEN THE 
SELECT EXECUTE MODE IS USED. 

THIS CODE IS USED WHEN A SPECIFIER EVALUATION 
WANTS TO WRITE DATA. THIS CODE CAN ALSO BE USED 
AS A LITERAL FOR AN EXECUTION ADDRESS WHEN THE 
SELECT EXECUTE MODE IS USED. 

THIS CODE IS USED DURING A READ-MODIFY-WRITE. 
THIS INFORMS THE TRANSLATION BUFFER THAT THE OP- 
ERATION IS A READ WITH A WRITE CHECK. THIS CODE 
CAN ALSO BE USED AS A LITERAL FOR AN EXECUTION 
ADDRESS WHEN THE SELECT EXECUTE MODE IS USED. 

THIS CODE IS USED WITH INTEGER DATA TYPES. 
REFER TO THE CONTEXT TABLE FOR COMMON USES 
OF THIS CODE. 

THIS CODE IS USED WITH FLOATING DATA TYPES. 
REFER TO THE CONTEXT TABLE FOR COMMON USES 
OF THIS CODE. 

THIS CODE IS ONLY USED WITH FIELD INSTRUCTIONS. 
IT IS USED WHEN THE CALCULATED EFFECTIVE ADDRESS 
IS USED AS THE OPERAND.THIS INCLUDES REGISTER 
ADDRESSES. 
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ASRC: ™IS CODE IS USED FOR INSTRUCTIONS THAT REQUIRE 

THE CALCULATED EFFECTIVE ADDRESS TO BE USED AS 
THE OPERAND. THIS EXCLUDES REGISTER ADDRESSES. 



MODE 


MNEMONIC 





S*# 


1 


S*# 


2 


S"# 


3 


s~# 


4 


E 


5 


R 


6 


<R) 


7 


-(R) 


8 


(R) + 


9 


@(R) + 


A 


D8 


B 


§D8 


C 


D16 


D 


3D 16 


E 


D32 


F 


@D32 



SPECIFIER DECODE TABLE 

R/-PC R=PC QUAD ABORT 



00 


00 


00 


00 


00 


00 


00 


00 


oc 


1C 


04 


14 


08 


18 


OA 


1A 


09 


19 


OB 


IB 


OD 


OD 


OF 


OF 


OD 


OD 


OF 


OF 


OD 


OD 


OF 


OF 



02 


01/03 


02 


01/03 


02 


01/03 


02 


01/03 


— 


ID 


6/16 


7/17,5/15 



IF 



CONTEXT TABLE 
LENGTH | TYPE | USE 



BYTE INTEGER BYTE DATA TYPE 

WORD INTEGER WORD DATA TYPE 

LONG INTEGER LONGWORD DATA TYPE 

QUAD INTEGER QUADWORD DATA TYPE 

BYTE FLOAT UNDEFINED 

WORD FLOAT UNDEFINED 

L0NG FLOAT FLOATING DATA TYPE 

QUAD FLOAT DOUBLE-FLOATING DATA TYPE 
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A. 2 ABORT CONDITION 

ABORT CONDITIONS: THE FOLLOWING IS A LIST OF ABORT ADDRESSES 

AND THE CONDITIONS WHICH CAUSE THEM TO BE 
GENERATED. 



ADDRESS 



CONDITIONS 



01 11. WRITING INTO A SHORT LITERAL. 

1 2. E MODE FOLLOWED BY A SHORT LITERAL. 

1 3. USING A SHORT LITERAL AS AN VSRC OR ASRC 


03 | QUAD CONTEXT AND 

1 1. WRITING INTO A SHORT LITERAL. 

1 2. E MODE FOLLOWED BY A SHORT LITERAL. 

1 3. USING A SHORT LITERAL AS AN VSRC OR ASRC 


05 | 1. USING REGISTER MODE FOR AN ASRC. 

1 2. E MODE FOLLOWED BY REGISTER MODE. 


07 | CONTEXT TYPE IS QUAD AND 

1 1. USING REGISTER MODE AS AN ASRC. 

1 2. E MODE IS FOLLOWED BY REGISTER MODE. 


14 11. REGISTER MODE AND RN EQUALS PC 


15 | RN EQUALS PC AND 

I 1. USING REGISTER MODE AS AN ASRC. 

I 2. E MODE IS FOLLOWED BY REGISTER MODE. 


16 | RN EQUALS PC WITH QUAD CONTEXT. 


17 | CONTEXT IS QUAD AND "RN" IS EQUAL TO PC 

1 1. USING REGISTER MODE AS AN ASRC. 
1 2. E MODE IS FOLLOWED BY REGISTER MODE. 


18 | THE ADDRESSING MODE IS REGISTER DEFFERED 

I AND "RN" IS EQUAL TO PC. 


1A | THE ADDRESSING MODE IS AUTO DECREMENT 

I AND THE "RN" IS EQUAL TO THE PC. 


1C | 1. E MODE WITH THE "RN" EQUAL TO PC. 


ID | 1. E MODE FOLLOWED BY E MODE. 
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00 



HALT 



EXC PT 


LENGTH 


TYPE 


ACCESS 


NODE 


ADDRESS 


EPO 


LONG 


INT 


READ 


EXECUTE 





EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 


01 


NOP 










EXC PT 


LENGTH 


. TYPE 


ACCESS 


MODE 


ADDRESS 


EPO 


LONG 


INT 


READ 


EXECUTE 


1 


EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 



02 



REI 



EXC PT 


LENGTH 


TYPE 


ACCESS 


MODE 


ADDR 


EPO 


LONG 


INT 


READ 


EXECUTE 


2 


EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 
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03 


BPT 




EXC PT 


LENGTH 


TYP1 


EPO 


LONG 


INT 


EP1 


LONG 


INT 


EP2 


LONG 


INT 


EP3 


LONG 


INT 


EP4 


LONG 


INT 


EP5 


LONG 


INT 


EP6 


LONG 


INT 


EP7 


LONG 


INT 



ACCESS 


MODE 


ADDRESS 


READ 


EXECUTE 


3 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 


READ 


EXECUTE 


8 



04 



RET 



EXC PT 


LENGTH 


TYPi 


EPO 


LONG 


INT 


EP1 


LONG 


INT 


EP2 


LONG 


INT 


EP3 


LONG 


INT 


EP4 


LONG 


INT 


EP5 


LONG 


INT 


EP6 


LONG 


INT 


EP7 


LONG 


INT 



ACCESS 

READ 
READ 
READ 
READ 
READ 
READ 
READ 
READ 



MODE 


ADDRESS 


EXECUTE 


4 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 



05 



RSB 



EXC PT 


LENGTH 


TYPi 


EPO 


LONG 


INT 


EP1 


LONG 


INT 


EP2 


LONG 


INT 


EP3 


LONG 


INT 


EP4 


LONG 


INT 


EP5 


LONG 


INT 


EP6 


LONG 


INT 


EP7 


LONG 


INT 



ACCESS 

READ 
READ 
READ 
READ 
READ 
READ 
READ 
READ 



MODE 


ADDRESS 


EXECUTE 


5 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 
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06 


LDPCTX 










EXC PT 


LENGTH 


TYPE 


ACCESS 


MODE 


ADDRESS 


EPO 


LONG 


INT 


READ 


EXECUTE 


6 


EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 


07 


SVPCTX 










EXC PT 


LENGTH 


TYPE 


ACCESS 


NODE 


ADDRESS 


EPO 


LONG 


INT 


READ 


EXECUTE 


7 


EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 



08 



CVTPS 



EXC PT 


LENGTH 


TYPE 


ACCESS 


MODE 


ADDRESS 


EPO 


WORD 


INT 


READ 


SELSPC 





EP1 


BYTE 


ASRC 


READ 


SELSPC 





EP2 


LONG 


INT 


BRANCH 


EXECUTE 


F 


EP3 


LONG 


INT 


BRANCH 


EXECUTE 


A 


EP4 


WORD 


INT 


READ 


SELSPC 





EP5 


BYTE 


ASRC 


READ 


SELSPC 





EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


WRITE 


EXECUTE 


3 
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09 


CVTSP 










EXC PT 


LENGTH 


TYPE 


ACCESS 


MODE 


A DDR 


EPO 


WORD 


INT 


READ 


SELSPC 





EP1 


BYTE 


ASRC 


READ 


SELSPC 





EP2 


LONG 


INT 


BRANCH 


EXECUTE 


F 


EP3 


LONG 


INT 


BRANCH 


EXECUTE 


E 


EP4 


WORD 


INT 


READ 


SELSPC 





EP5 


BYTE 
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READ 



MODE 

EXECUTE 
EXECUTE 
EXECUTE 
EXECUTE 
EXECUTE 
EXECUTE 
EXECUTE 
EXECUTE 



ADDRESS 

A 
8 
8 
8 
8 
8 
8 
8 



FE 

EXC PT 

EPO 
EP1 
EP2 
EP3 
EP4 
EP5 
EP6 
EP7 



ESCE 

LENGTH 

LONG 
LONG 
LONG 
LONG 
LONG 
LONG 
LONG 
LONG 



TYPE 

INT 
INT 
INT 
INT 
INT 
INT 
INT 
INT 



ACCESS 

READ 
READ 
READ 
READ 
READ 
READ 
READ 
READ 



MODE 


ADDRESS 


EXECUTE 


E 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 


EXECUTE 


8 
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FF 



ESCF 



EXC PT 


LENGTH 


TYPE 


ACCESS 


MODE 


ADDR 


EPO 


LONG 


INT 


READ 


EXECUTE 


C 


EP1 


LONG 


INT 


READ 


EXECUTE 


8 


EP2 


LONG 


INT 


READ 


EXECUTE 


8 


EP3 


LONG 


INT 


READ 


EXECUTE 


8 


EP4 


LONG 


INT 


READ 


EXECUTE 


8 


EP5 


LONG 


INT 


READ 


EXECUTE 


8 


EP6 


LONG 


INT 


READ 


EXECUTE 


8 


EP7 


LONG 


INT 


READ 


EXECUTE 


8 



APPENDIX B 
WRITABLE CONTROL STORE 



B.l WRITEABLE CONTROL STORE MEMORY 

The writable control store memory consists of 1024 words. Each word 
contains 96 data bits, of which 3 parity bits (1 per each 32 bits of 
data) . The Control Store (CS) bus outputs are tri-state. 

TTL HIGH = "1" 

TTL LOW = "0" The normal parity generated is even. 



B.2 WRITE DATA TO WCS 

The write sequence will require two machine cycles. The first being 
the writing of the WCS address register from the ID bus. The second 
being the writing of the WCS data to WCS memory from the ID bus. The 
write WCS address cycle and the WCS write data cycle may either be 
consecutive cycles or the address may be loaded and sometime later the 
data may be loaded. 

The same IK module of WCS MUST NOT be the control store in use by the 
CPU and have a WCS write data operation being performed on it during 
the same machine cycle. The data written into WCS is in true form. 
Writing WCS under console control is done by writing the WCS address 
register and then doing a WCS write data operation for each 32 bits of 
data to be written. 

The WCS address counter bits <14:13> (on the micro sequencer) are 
loaded with a WCS write address command. These stages are a modulo-3 
counter that selects the 32 bit data group to be written. At the end 
of each WCS write data command the counter is incremented, when the 
modulo-3 counter overflows; the WCS address register bits <12:00> are 
incremented by one. 
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B.3 WCS ADDRESS REGISTER 


Layout 
15 


14 13 


I PARITY | 
I INVERT | 


1 1 1 
| MODULO | 
13 1 1 
| COUNTER | 



12 



00 



WCS ADDRESS REG. AND 
<12:00> COUNTER 



BIT 15 = 1 


= INVERT PARITY 




= 


= NORMAL PARITY 




BIT<14:13> 


= 00 = GROUP A = DATA 


BITS<31:00> 




= 01 = GROUP B ■ DATA 


BITS<63:32> 




=10 GROUP C = DATA 


BITS<95:64> 




=00 GROUP A 





B.4 EXTERNAL JUMPER SELECTIONS AND RAM TYPE SELECTION 



or switches for 
the WCS module. 



There are five back panel pins to be used with jumpers 

selecting the one of eight IK segments to be assigned 

The voltage level will be at '0' volts with jumper installed and at 

■+3' volts with the jumper removed. The jumper (J5) when out selects 

the lower 4K area, and when in selects the upper 4K area. The jumpers 

Jl, J2, J3, J4 are to select a WCS module for a particular IK area 

from a possible of four IK areas. 



Jl 



J2 



J3 



J4 



MEM BANK SELECTED 



OUT 


IN 


IN 


IN 


1ST 


IK 


SEGMENT 


X 


OUT 


IN 


IN 


2ND 


IK 


SEGMENT 


X 


X 


OUT 


IN 


3RD 


IK 


SEGMENT 


X 


X 


X 


OUT 


4TH 


IK 


SEGMENT 



DON'T CARE CONDITION 



There is 

control 

register 

control , 

bits <07 

available 

segments. 



a provision for reading the summary of available writeable 
store segments by doing an ID bus read of the WCS memory data 
When this command is received by the micro sequencer 
a signal is generated which tells all WCS modules to transmit 
00> onto the ID bus. ID bus bit 00 represents the 1st IK of 
WCS and bit 07 represents the 8th IK of available WCS memory 



APPENDIX C 
MICRO-CODE DEBUGGER INTERFACE 



C.l OBJECTIVES 

Develop a tool needed to debug micro-programs, both in ROM & WCS. 
Features required and specified here-in are: 

- Entry & Exit, Micro-code Debugger 

- Micro-Machine State control 

- Examine & Deposit to Internal Registers 

- Examine Control Storage Location 

- Deposit to WCS Location 

Also covered are the expected usage restrictions. 

"The prime objective of the micro-code debugger is to allow the 

user to micro-step his micro-program and to examine the 

micro-machines internal registers without destroying the 
micro-machine's state". 



C.2 MICRO-CODE DEBUGGER ENTRY & EXIT 

The Micro-Code Debugger may be entered from the console program by 
WCS. The console program is re-entered upon exit from the Micro-code 
debugger . 

The transfer between the micro-code debugger and the console program, 
on both entry and exit, can occur without loss of micro-machine state 
if the micro-machine's clock is running or stopped. 

On both entry and exit, the program (LSI-11) entered is in its 
initialized state. 
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Specific features provided are: 

1. Load Micro-Code Debugger 

If the micro-machine is running or stopped, allow the 
Micro-code debugger program to be loaded such that the 
micro-machine can be continued correctly upon the debugger 
assuming control of the micro-machine. 

2. Load Console Program 

If the micro-machine is running or stopped, allow the console 
program to be loaded such that the micro-machine can be 
continued correctly upon the console program assuming control 
of the micro-machine. 



C.3 MICRO-CODE DEBUGGER- MICRO-MACHINE- STATE CONTROL 

On entry to the Debugger from the Console program, the micro-machine 
can be either running or stopped in any TIME STATE (T0-T3) . (time 
state readable over V-Bus by console) 

If it is stopped the micro-code debugger will advance the clock using 
single state step IMO "T3" and will put the micro-machine into the 
micro-step mode. 

On stopping the micro-machine (or on initial entry if stopped) , the 
micro-code debugger will examine the Machine State and the next 
micro- instruction to be executed to determine if it is dependent upon 
the current micro-machine state; if so, special action is required by 
the micro-code debugger (later referred to as a dependent 
micro-instruction) : 

"STALL" Asserted 

If "stall" is asserted, the micro-debugger will "single time 
state" the micro-machine until "stall" is de-asserted during T3 
by the micro-machine. (if not de-asserted after 600 

micro-machine cycles, Error Message is printed). 

"Dependent Micro-Instruction" 



The micro-code debugger will examine the next micro-instruction 
to be executed to determine if it is a dependent one. This is 
done by comparing each of the micro-orders in the 
micro-instruction against a list of dependent micro-orders. If 
any exist, a warning message is printed on the console, not to 
use the micro-debugger's examine & deposit features. 
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Specific features are: 

1. Enter Micro-Step Mode 

The debugger will be entered into the Micro-Step Mode if the 
Micro-Machine is stopped. 

2. Micro-Step 

If the micro-machine is stopped, the micro-machine will 
execute one micro-instruction and then stop during T3 prior 
to starting execution of the next micro-instruction. 

Also single state stepping of the micro-machines clock is 
required through the micro-instruction for several reasons, 
i.e., setup time required for "slow constants". 

3. Leave Micro-Step Mode 

The debugger will leave Micro-Step Mode & the micro-machine 
will start running at normal clock speed at the address in 
the UPCSV on the next "proceed" command. 

4. Set Micro-Break (SOMM) 

If the micro-machine is stopped, the "SOMM" bit will be set, 
and On, "PROCEED". The micro-machine will be stopped after 
executing the micro-instruction whose address is specified in 
ID[21]. 

This feature uses the micro-machine's stop-on-micro-break 
match feature to stop itself during TO of the addressed 
micro-instruction. Then the micro-debugger will advance 
execution of the current instruction into "T3" state. 

The micro-machine will remain stopped until it gets a 
"proceed" command. 

5. STOP 

If the clock is running, this feature will stop it and 
advance it into "T3" of the next micro-instruction. 

In addition the micro-code debugger will implement a number of 
switches, etc. to allow micro-breaking on a list of micro-addresses 
using the micro-step feature, i.e., Proceed/B. 
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C.4 MICRO-CODE DEBUGGER INTERNAL REGISTER & MEMORY EXAMINE & DEPOSIT 

The following internal registers and memory may be examined and/or 
modified using this feature. Since the micro-state of the 
micro-machine may be modified by the supporting micro-routines in the 
micro-machine, the micro-code debugger prints a warning message when 
this will occur. (specified earlier in the spec.) 

The user can generally get around this problem by entering the machine 
into micro-step mode, and micro-stepping the micro-machine until a 
warning message is not printed. 

The micro-machine facilities that can be examined and or modified are: 

IBA, Q, VA, MICRO-PC, D, SC, LA, LB, STATE LC, FE, PC, RLOG & PCSV 
(R.O.), RA, RC, ID, & MEMORY. 

The micro-code debugger completes execution of the current 

micro-instruction by advancing the clock using single state step into 

TO and applying "ROM NOP" to stop starting execution of the next 
micro-instruciton. 

Then micro-code debugger saves and restores the various registers that 

can be indirectly changed by the supporting micro-routines so that 

micro-machine can be successfully restarted (if a warning message was 
not printed) on the next micro-instruction to be executed. 

On debugger initiated memory references, the user must clear 
ID-Registers, TBERl, SBI.ERR, & PARITY if a memory exception occurs 
and he wants to continue his micro-program. 

Deposits & Examines to memory during memory management firmware will 
destroy the micro-machine state (no warning printed) . 



Examine Control Store Location 

Since the control store cannot be read by the debugger, the micro-code 
debugger examines a load image file that has been opened on a floppy 
disk and prints the contents of the field(s) requested. (warning 
messages can be ignored) 



Deposit To WCS Location 

Deposits to the field (s) specified in WCS and on the load image floppy 
file. 

Previous warning messages must be observed. 
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C.5 LIST OF DEPENDENT MICRO-ORDERS 



PRINT WARNING MESSAGE* 
BEFORE AFTER 



ACF/SYNC 

BEN/ALU 1-0. NEQ. ZERO 

BEN/TB.TEST 

FS/=0&MCT/(ALL CODES EXCEPT 
"ALLOW. IB. READ) 

FS/=0&MCT/LOCKREAD.V.NOCHK 
LOCKREAD.V.WCHK 
SB I. HOLD 
SBI.HOLD+UNJAM 
LOCKREAD.P 

SUB/SPEC 



* 
* 



Sequences that must be avoided using micro-step: 



1. Interlocked read/writes. 



2. SBI UN JAM sequence. 



3. I/O programs. 



4. CS parity error. 



5. Memory Examine/Deposit during memory management F/W. 

On sequences 1), 2), & 5) above, Micro-break match can be set to a 
micro-instruction following the sequence, then clearing "step" and 
then doing the "Proceed" command will execute the sequence at machine 
speed, allowing the micro-programmer to skip over these problems. 



* Before or after execution of next micro-instruction. 
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Future Possible Enhancements 

1. Reducing restrictions on MCT/FIELD micro-orders. 

By reading over the V-Bus, determine if micro-trap is pending 
or not. If not, do not print warning message (associated 
one) . 

2. Examining ID Bus Registers without using Micro-Machine clock. 

When the machine is stopped during T3, allow examining of 
ID-REGS . 

If not in T3, use micro-code routine to do the examine after 
asking the user if he wants to destroy the machine state. 

3. Examine/Deposit after Warning Message. 

Ask user if he really wants to destroy state. If response is 
"YES", do requested Examine or Deposit. 



APPENDIX D 
WCS DEBUGGER HELP FILE 

The WCS Debugger help file may be accessed by typing at the console: 

>>>@WCSMON.HLP 
To call the WCS debugger, type at the console: 

»>WCS 

MICRO-DEBUGGER HELP FILE REV-0 MAY 1977 
TO STOP PRINTING, TYPE C 

DEBUGGER COMMANDS (ALL TERMINATED BY CARRIAGE RETURN) 

•E/P <ADDRESS>' -EXAMINE PHYSICAL MEMORY 

•E/ID <ADDRESS>' -EXAMINE ID BUS REGISTER 

'E <ADDRESS>' -EXAMINE WCS LOCATION, DISPLAY ALL FIELDS 

'E <ADDRESS> <FIELDNAME-l>,<FIELDNAME-2>, , , ,<FIELDNAME-N> 

EXAMINE WCS LOCATION, DISPLAY ONLY FIELDS 
THE FIELDS SPECIFIED 
NOTE: <FIELDNAMES> = ACF,ACM,ADS,ALU,BEN,BMX,CCK,CID,DK,DT,EAL 

EBM,FEK,FS,IBC,IEK,UJM,KMX,MCT,MSC,PCK,QK 
RMX,SCK,SGN,SHF,SI,SMX,SPO,USU,VAK 

"E RA <ADDRESS>' -EXAMINE AN RA REGISTER 

'E RC <ADDRESS>' -EXAMINE AN RC REGISTER 
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•E <SYMBOLIC-NAME>' -EXAMINE ONE OF THE SYMBOLICALLY NAMED 

REGISTERS 
NOTE: <SYMBOLIC-NAMES> = DR,FER, IBA, LA, LB, LC,Q f RL,SC,SR,UPC 

•D/P <ADDRESS> <DATA> » -DEPOSIT <DATA> TO PHYSICAL MEMORY 

•D/ID <ADDRESS> <DATA>' -DEPOSIT <DATA> TO ID BUS REGISTER 

•D <ADDRESS> <FIELDNAME-1> <DATA-l>,<FIELDNAME-2> <DATA-2>, 

-DEPOSIT TO WCS LOCATION, PUTTING <DATA-1> 
INTO <FIELDNAME-1>, ETC. UNSPECIFIED FIELDS 
ARE UNCHANGED. 
NOTE: THE */Z' QUALIFIER MAY BE USED TO CAUSE ALL UNSPECIFIED 
FIELDS TO BE CLARED. 

•D RA <ADDRESS> <DATA>' -DEPOSIT <DATA> TO AN RA REGISTER 
'D RC <ADDRESS> <DATA>' -DEPOSIT <DATA> TO AN RC REGISTER 

'D <SYMBOLIC-NAME> DATA> ' -DEPOSIT <DATA> TO ONE OF THE SYMBOLICALLY 

NAMED REGISTERS (SEE LIST ABOVE). 
NOTE: DEPOSITS TO THE RLOG STACK (RL) ARE NOT SUPPORTED. 

•CONTINUE' -RESUME MICRO-INSTRUCTION EXECUTION AS 

SPECIFIED BY CONTENTS OF MICRO-PC (UPC) 

. 'START <ADDRESS>' -START MICRO-SEQUENCER AT <ADDRESS>. 

•HALT' -HALT THE MICRO-SEQUENCER 

'SET SOMM' -SET THE 'STOP ON MICRO-MATCH' ENABLE 

•CLEAR SOMM' -CLEAR THE 'STOP ON MICRO-MATCH' ENABLE 
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•SET STEP' 



-ENABLE SINGLE MICRO-INSTRUCTION STEP MODE. 
START OR CONTINUE WILL ALLOW ONE MICRO- 
INSTRUCTION TO EXECUTE, THEN HALT THE 
MICRO-SEQUENCER. 



'CLEAR STEP' 



-DISABLE SINGLE MICRO-INSTRUCTION STEP MODE. 



"RETURN 



-RETURN TO THE CONSOLE PROGRAM 



•OPEN <FILENAME>' -OPEN SPECIFIED FILE ON FLOPPY DRIVE 

•OPEN DX1:<FILENAME>' -OPEN SPECIFIED FILE ON FLOPPY DRIVE 1 

NOTE: 'OPEN' IS USED TO SPECIFY A FILE CONTAINING THE MICRO-CODE 

CURRENTLY LOADED IN THE WCS PORTION OF THE CONTROL STORE. 

(ADDRESSES 1000 (16) & UP IN THE CONTROL STORE) 

THIS FILE WILL BE USED FOR ALL EXAMINES OF THE WCS, 

SINCE THE WCS IS NOT DIRECTLY READABLE. 



APPENDIX E 
PROM CONTROL STORE SPECIFICATION 

The control store (CS) bus outputs are tri-state 

TTL HIGH = "1" 
TTL LOW = "0" 

CS bus output loading by other subsystems 

A maximum of 2 loads/bit, external to the control store and the micro 
sequencer modules will be allowed. User receivers are to be within 6 inches 
of the module fingers. 



E.l PROM ADDRESS PATH 

The PROM address is selected by Micro Program Counter (UPC) bits <09:00>. 
UPC Bit <12> selects either the lower 4K bank or the higher 4K bank of PROM. 
UPC Bits <11:10> select one of the four IK segments to be accessed. 



E.2 PARITY ERROR DETECTION 

The parity tree is 99 bits wide and is done in two levels. The parity 
checking is for 96 data bits and 3 parity bits. Each parity bit makes up 
even parity for 32 consecutive data bits. That is, there will be an even 
number of l's in the 33 bit field (32 data and 1 parity). For example: 

BIT 31 30 29 3 

10 1 < > 1 

10 < > 1 

If the micro program tried to access non-existant control store memory, then 
NO CS bus drivers would be enabled. This would cause an all l's condition 
including parity on the CS bus due to the terminator pull-up resistor. The 
parity error detection logic will see this as odd parity and flag a micro 
word parity error, then resulting in a micro trap. 



2 


1 





PARITY 













1 


EVEN 














EVEN 
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E.3 EXTERNAL JUMPER SELECTIONS AND CS TYPE SELECTION 

There are five back panel pins to be used with jumpers or switches for board 
and segment selection. The jumper (J5) when in selects the lower 4K bank, 
and when out selects the upper 4K bank. The jumpers Jl, 32, J3, J4 each 
select a IK segment when removed. When a jumper is in, that particular IK 
segment is disabled. 

Jl selects or disables the 1st IK segment 

J2 selects or disables the 2nd IK segment 

J3 selects or disables the 3rd IK segment 

J4 selects or disables the 4th IK segment 
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INDEX 



Abort Condition, A-5 

Aborts, 5-13 

ACC CONTROL/STATUS, 3-8 

ACC MAINT, 3-8 

ACC REG #0 THRU #1, 3-8 

Accelerator control, 9-7 

ACCELERATOR INTERFACE, 4-11 

ACCELERATOR interface operation, 

9-6 
Accelerator maintenance register, 

9-9 
Accelerator status registers, 9-9 
Accelerator trap, 9-7 
Access control violation - fault, 

5-18 
Acknowledging exceptions, 5-23 
ADDRESS BUS, 7-2 
Address Section, 1-51 
Address section 

data path, 1-51 
Al ignment 

byte, 1-46 

data, 1-37 

memory data byte, 1-44 
Alternate data transfers, 9-9 
Alternate trap function, 9-7 
ALU, 1-3 

A input multiplexor, 1-5 

B input multiplexor, 1-7 
AMX, 1-5 

Arithmetic and logic unit, 1-3 
Arithmetic Section, 1-3 
Arithmetic section 

data path, 1-3 
Arithmetic trap - TRAP, 5-21 
Arithmetic trap acknowledging, 

5-23 
Asynchronous system trap level reg 

ASTR, 5-11 

BAL, 1-46 

Bit field too wide - fault, 5-16 

Bit mask generator, 1-18 

BMX, 1-7 

BPT opcode - FAULT, 5-20 

Branch Enable Field (uBen) , 2-8 

BUFFER DATA PATH, 4-1 

Buffer Register, 4-1 



BUS DFMX, 1-34 

Byte alignment, 1-46 

BYTE ROTATOR, 4-4 

CACHE INTERFACE, 4-11 

Cache parity error, 5-15 

Cache Stalls, 2-6 

Call Subroutine, 2-9 

CHMX instructions, 5-25 

CHMX opcodes, 5-22 

Classes of exceptions, 5-13 

CLOCK BUS, 7-2 

CLOCK CONTROL/STATUS, 3-6 

CNSL halt, 5-24 

CNSL RXCS, 3-5 

CNSL RXDB, 3-6 

CNSL TXCS, 3-6 

CNSL TXDB, 3-6 

Compatability mode trap 

TRAP/ABORT, 5-20 
Console Control of ID BUS, 3-5 
Console controlled Operations, 

2-11 
Console Terminal Interrupts, 5-7 
Context Lookup, 4-8 
Control store parity error, 5-15 
Control Store Parity Error 

Micro Trap mode, 2-4 
Control store parity error 

trap mode, 2-4 
CPU branches, 9-7 
CPU ERROR/STATUS, 3-14 
CPU Power Fail, 5-5 
CPU Timeout, 5-5 

Cpu/console interface state, 6-6 
CRD/RDS , 5-6 
CS BUS, 7-1 

D, 1-41 

D PGEN, 1-46 

D register, 1-41 

multiplexor, 1-36 

parity generator, 1-46 
D,Q (MAINT MODE ONLY), 3-13 
DAL, 1-37 

Data alignment, 1-37 
Data format multiplexor, 1-33 
Data from accelerator, 9-8 
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DATA INTERFACE, 9-8 

Data Length Field, 4-9 

Data path 

address section, 1-51 
arithmetic section, 1-3 
data section, 1-33 
exponent section, 1-26 

Data Section, 1-33 

Data section 

data path, 1-33 

Data to accelerator, 9-8 

Data transfer, 9-6 

Decimal string too long - fault, 
5-18 

Definitions, 9-2 

Description of 

exception conditions, 5-14 
Interrupt Conditions, 5-5 
utrap conditions, 5-26 

DFMX, 1-33 

DMX, 1-36 

EALU, 1-26 

EAMX, 1-27 

EBMX, 1-28 

ECO control, 2-1 

Error acknowledging, 5-23 

Error logout, 6-3 

Errors, 5-26 

Exception conditions 

and their vectors, 5-13 
Exceptions, 5-12 
EXECUTION POINTS, 4-9 
Exponent 

ALU, 1-27 

arithmetic logic unit, 1-26 
Exponent Section, 1-26 
Exponent section 

data path, 1-26 
External Device Interrupts, 5-7 
External jumper selections and 

cs type selection, E-2 

ram type selection, B-2 

Fast constant multiplexor, 1-14 

Faults, 5-13 

FE, 1-29 

FIRST PART DONE, 4-10 

FK, 1-14 

FPDA, D.SV, Q.SV, 3-16 

From data path - none, 7-6 



FROM IB, 7-2 

FROM MICROSEQUENCER, 7-3 

FROM TRAPS AND INTERRUPTS, 7-4 

Functional Operation, 3-1 

General description, 7-30 
General register updates, 9-9 

Halt code from vector, 5-25 
Halt conditions, 5-24 
Halt identification codes, 6-7 
Halt Instruction, 5-24 

I -STREAM DATA MUX, 4-5 

IB Addressing, 4-10 

IBUF DATA, 3-5 

ID bus, 3-1 

ID BUS Addresses, 3-2 

ID BUS Control, 3-3 

ID BUS Data, 3-3 

ID BUS Register Description, 3-5 

Id bus registers on cib, 8-6 

Illegal entry mask - fault, 5-17 

Illegal floating number -'fault, 

5-16 
Illegal Machine Sequence Error, 

5-15 
Illegal PCB entry - abort, 5-17 
Illegal processor reg - fault, 

5-17 
Illegal PSL image - fault, 5-17 
Initial data transfer, 9-6 
Initialization of cp, tbuf, cache, & 

sbi status registers, 6-6 
Initialize, 2-7 
INPUT MULTIPLEXER, 4-4 
Instruction aborts, 6-2 
Instruction faults, 6-3 
Instruction halts, 6-3 
Interface specification, 9-2 
Internal data bus, 3-1 

control, 3-3 

directional control, 3-3 

normal operation, 3-1 
Internal register, C-4 
Interrupt Acknowledge, 5-8 
Interrupt Priority Level (IPL), 

5-1 
Interrupt priority level register 

IPLR, 5-9 
Interrupt Requests 
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and their Vectors, 5-3 
Interrupt stack not valid, 5-25 
Interrupt Strobe, 5-8 
Interrupts, 5-1 
INTERVAL COUNT, 3-7 
Interval Timer, 5-6 
IR DECODE, 4-7 
ISB INTERFACE, 9-10 

JFIELD, 2-8 

Jump field, 2-8 

Jump Field (JField or uJMP) , 2-8 

Kernel stack not valid 
raises IPL to IF, 5-16 

LA, 1-19 

LA and LB, 1-19 

Latch 

A, 1-19 

B, 1-19 

C, 1-18 
Latching 

UPC address, 2-14 
LB, 1-19 
LC, 1-18 

LIST OF DEPENDENT MICRO-ORDERS, 
C-5 

Machine check - raises IPL to IF, 

5-14 
Machine checks, 6-1 
Machine halts, 5-24 
Maintenance Operation, 3-4 
MASK, 1-18 
MBIT, 5-26 
MD BUS, 7-1 
MDBAL, 1-44 

Memory data byte alignment, 1-44 
MICRO Control Use, 4-3 
Micro ECO control (UECO) Mode, 2-1 
Micro sequencer 

ECO control mode, 2-1 

normal mode, 2-1 

parity error trap mode, 2-4 

trap mode, 2-3 
Micro Subroutine Field (USUB) , 2-8 
Micro Trap (UTRAP) Mode, 2-3 
MICRO-CODE DEBUGGER, C-2, C-4 

ENTRY & EXIT, C-l 
MICRO-MACHINE State Control, C-2 



Microbranches, 7-6 
Microcoding suggestions, 7-31 
MICROORDERS, 7-7 
Multiplexer Shift Network, 4-2 
Multiplexors 

ALU A input, 1-5 

ALU B input, 1-7 

constant, 1-14 
fast, 1-14 
slow, 1-14 

NEXT INTERVAL COUNT, 3-7 
NMX, 1-55 
Normal Mode, 2-1 
Normal Operation, 3-1 
Number multiplexor, 1-55 



Objectives, C-l 
Other Fields 
UBS+UBCT (not 



on USC) , 2-9 



POLR, P1LR, SLR, PCBB, 
SSP, USP, ISP, 



POBR, P1BR, SBR, 

SCBB KSP, ESP, 
3-16 

Page boundary, 5-26 
Parity error 

trap mode, 2-4 
Parity error detection, E-l 
Parity generator 

D register, 1-46 
PC, 1-54 
PC UPDATES, 4-6 
PCADD, 1-55 
PCAMX, 1-56 
PCMX, 1-56 
PCSV, 1-25 
Pico sequencer, 2-13 

and Priority decoding, 2-13 
Power 

down, 2-10 

up, 2-10 
Power up or Down, 2-10 
Priority decoding, 2-13 
Program counter, 1-54 

adder, 1-55 

adder multiplexor, 1-56 

multiplexor, 1-56 
Program counter save register, 

1-25 
Prom address path, E-l 
Protection violation, 5-26 
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PSL, 3-13 

PSW MBZ FIELD not zero - fault, 
5-17 

Q, 1-38 

Q register, 1-38 

multiplexor, 1-35 
QMX, 1-35 

RA, 1-19 

RAMX, 1-50 

RB, 1-19 

RBMX, 1-50 

RC, 1-18 

Read data substitute, 5-15 

Read timeout, 5-14 

Register AMX multiplexor, 1-50 

Register BMX multiplexor, 1-50 

Register Latched Number, 4-8 

Register log stack, 1-25 

Register set 

A, 1-19 

B, 1-19 

C, 1-18 
REGISTERS, 7-11 
Registers used for 

interrupt servicing, 5-9 
Reserved 

addressing modes - fault, 5-18 

cust opcodes, 5-16 

DEC opcodes & priv. instr, 5-16 

floating operand, 5-26 

operands, 5-16 

pattern operator - Fault, 5-18 
Retryable Instruction List, 6-8 
Return Subroutine, 2-9 
RLOG, 1-2 5 

SBI Alert, 5-6 

SBI CACHE PARITY, 3-11 

SBI Fault, 5-5 

SBI FAULT/STATUS, 3-10 

SBI MAINTENANCE, 3-11 

SBI SILO, 3-9 

SBI SILO COMPARATOR, 3-10 

SBI SILO Compare, 5-6 

SBI TIMEOUT ADDRESS, 3-10 

SC, 1-32 

Scratch pad control, 1-20 

Selected internal 

subsystem signals, 7-6 



Sequencer, 2-1 
Serialization of events 

at Fork A, 5-27 
SHF, 1-11 

SHIFT NETWORK, 4-2 
Shifter, 1-11 
Signal Summary, 3-3 
SIR, 3-13 
SK, 1-14 

Slow constant multiplexor, 1-14 
SMX, 1-31 
Software interrupt 

request register - SIRR, 5-12 

summary register - SISR, 5-11 
Software Interrupts, 5-7 
Specifier 1 Constant, 4-8 
Specifier 2 Constant, 4-9 
Stalls 

cache, 2-6 
STATE, 1-30 
System clock, 9-8 
System Control Block, 5-2 
System control block 

base register - SCBB, 5-9 
SYSTEM ID, 3-5 
System init, 5-26 
System Initialize, 2-7 

TBUF DATA, 3-8 

TBUF miss, 5-26 

TBUF REG0, 3-9 

TBUF REG1, 3-9 

Terminal Control Registers 

in the Procreg Space, 8-26 
The console/cpu interface, 8-3 
The Control Word, A-l 
The q-bus registers, 8-8 
TIME OF DAY, 3-7 
TO DATA PATH, 7-6 
TO IB, 7-3 

TO MICROSEQUENCER, 7-3 
TO TRAPS AND INTERRUPTS, 7-4 
Trace trap - TRAP, 5-20 
Trace trap acknowledging, 5-23 
Translation buffer parity error, 

5-15 
Translation not valid - fault, 

5-19 
Trap mode, 2-3 
Traps, 5-13 
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UALU, 1-4 

UAMX, 1-7 

UBMX, 1-10 

UBREAK, 3-12 

UDK, 1-43 

UDT, 1-7, 1-14 

UEALU, 1-27 

UEBMX, 1-29 

UECO, 2-1 

UFEK, 1-30 

UJMP, 2-8 

Unaligned data, 5-26 

UPC address latching, 2-14 

UPCK, 1-55 

UQK, 1-40 

Use of the q-bus registers, 8-20 

USGN, 1-10 

USHF, 1-13 

USI, 1-13, 1-41 

USMX, 1-32 

USTACK, 3-11 

USUB, 2-8 

UTRAP, 2-3 

conditons and their vectors, 
5-25 

function, 5-25 
UWORD control for exceptions, 5-24 
UWORD Control for Interrupts, 5-8 

V BUS, 7-2 

VA, 1-52 

VAMUX, 1-53 

VECTOR, 3-15 

Vector register, VECTOR, 5-10 

Vectors, 5-2 

VIBA, 1-51 

Virtual address 

counter, 1-52 

multiplexor, 1-53 
Virtual instruction buffer 

address counter, 1-51 

WCS ADDRESS, 3-12 
Wcs address register, B-2 
WCS DATA/STATUS, 3-12 
Write data to wcs, B-l 
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